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Chapter 1 

Z8000 Processor Overview 



1.1 Intro- This chapter provides a summary description 

duction of the advanced architecture of the Z8000 

Microprocessor, with special attention given to 
those architectural features that set the Z8000 
CPU apart from its predecessors. A complete 



overview of the architecture is provided in 
Chapter 2, with detailed descriptions of the 
various aspects of the processor provided in 
succeeding chapters. 



1.2 General Zilog's Z8000 microprocessor has been 

Organization designed to accommodate a wide range of 

applications, from the relatively simple to the 
large and complex. The ZBOOO CPU is offered 
in two versions: the Z8001 and the Z8002. Each 
CPU comes with an entire family of support 
components: a memory management unit, a 
DMA controller, serial and parallel I/O 
controllers, and extended processing units — all 
compatible with Zilog's Z-Bus. Together with 
other Z8000 Family components, the advanced 
CPU architecture provides in an LSI micro- 
processor design the flexibility and sophisti- 
cated features usually associated with mini- or 
mainframe computers. 

The major architectural features of the Z8000 
CPU that enhance throughput and processing 
power are a general purpose register file, 
system and normal modes of operation, multi- 
ple addressing spaces, a powerful instruction 
set, numerous addressing modes, multiple 
stacks, sophisticated interrupt structure, a rich 
set of data types, separate I/O address spaces 
and, for the Z8001, a large address space and 
segmented memory addressing. Each of these 
features is treated in detail in the next section. 
These architectural features combine to pro- 
duce a powerful, versatile microprocessor. The 



benefits that result from these features are 
code density, compiler efficiency, support for 
typical operating system operations, and com- 
plex data structures. These topics are treated 
in Section 1.3. 

The CPU has been designed so that a power- 
ful memory management system can be used to 
improve the utilization of the main memory 
and provide protection capabilities for the 
system. This is discussed in Section 1.3.12. 
Although memory management is an optional 
capability — the Z8000 CPU is an extremely 
sophisticated processor without memory 
management — the CPU has explicit features to 
facilitate integrating an external memory 
management device into a Z8000 system con- 
figuration. 

Finally, care has been taken to provide a 
very general mechanism for extending the 
basic instruction set through the use of extern 
al devices (called Extended Processing 
Units — FPUs). In general, an FPU is dedicated 
to performing complex and time-consuming 
tasks so as to unburden the CPU. Typical tasks 
for specialized FPUs include floating-point 
arithmetic, data base search and maintenance 
operations, network interfaces, and many 
others. This topic is treated in Section 1.5. 



1,3 Architec- The architectural resources of the Z8000 

tural Features CPU include sixteen 16-bit general-purpose 

registers, seven data types ranging from bits to 
32-bit long words and byte strings, eight user- 
selectable addressing modes, and an instruc- 
tion set more powerful than that of most mini- 
computers. The 110 distinct instruction types 
combine with the various data types and 
addressing modes to form a rich set of 414 
instructions. Moreover, the set exhibits a high 
degree of regularity: more than 90% of the 
instructions can use any of five main address- 
ing modes, with 8-bit byte, 16-bit word, and 
32-bit long- word data types. 

The CPU generates status signals indicating 
the nature of the bus transaction that is being 
attempted; these can be used to implement 
sophisticated systems with multiple address 
spaces — memory areas dedicated to specific 



uses. The CPU also has two operating modes, 
system and normal, which can be used to 
separate operating system functions from nor- 
mal application processes. I/O operations have 
have been separated from memory accesses, 
further enchancing the capability and integrity 
of Z8000-based systems, and a sophisticated 
interrupt structure facilitates the efficient 
operation of peripheral I/O devices. Moreover, 
the Extended Processing Unit (EPU) capability 
of the Z8000 allows the CPU to unload many 
time-consuming tasks onto external devices. 

Special features of the Z8000 have been 
introduced to facilitate the implementation of 
multiple processor systems. In addition, the 
Z8001 CPU has a large, segmented addressing 
capability that greatly extends the applica- 
bility of microprocessors to large system 
applications. 
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1.3 Architec- 1.3.1 General-Purpose Register File. The 
tural Features heart of the Z8000 CPU architecture is a file of 
(Continued) sixteen 16-bit general-purpose registers. These 
general-purpose registers give the Z8000 its 
power and flexibility and add to its regular 
instruction structure. 

General-purpose registers can be used as 
accumulators, memory pointers or index reg- 
isters. Their major advantage is that the partic- 
ular use to which they are put can vary during 
the course of a program as the needs of the 
program change. Thus, the general-purpose 
register file avoids the critical bottlenecks of 
an implied or dedicated register architecture, 
which must save and restore the contents of 
dedicated registers when more registers of a 
particular type are needed than are supplied 
by the processor. 

The Z8000 CPU register file can be 
addressed in several ways: as 16 byte registers 
(occupying one half of the file) or as 16 word 
registers or, by using the register pairing 
mechanism, as eight long-word (32-bit) reg- 
isters or as four guadruple-word (64-bit) 
registers. Because of this register flexibility, it 
is not necessary (for example) for a Z8000 user 
tp dedicate a 32-bit register to hold a byte of 
data. Registers can be used efficiently in 
the Z8000. 

1.3.2 Instruction Set. A powerful instruction 
set is one of the distinguishing characteristics 
of the Z8000. The instruction set is one 
measure of the flexibility and versatility of a 
computer. Having a given operation imple- 
mented in hardware saves memory and 
improves speed. In addition, completeness of 
the operations available on a particular data 
type is frequently more important than addi- 
tional, esoteric instructions, which are unlikely 
to affect performance significantly. The Z8000 
CPU provides a full complement of arithmetic, 
logical, branch, I/O, shift, rotate, and string 
instructions. In addition, special instructions 
have been included to facilitate multiprocess- 
ing, multiple processor configurations, and 
typical high level language and operating 
system functions. The general philosophy of 
the instruction set is two-operand register- 
memory operations, which include as a special 
subset register-register operations. However, 
to improve code density, a few memory- 
memory operations are used for string manipu- 
lation. The two-address format reflects the most 
frequently occurring operations (such as 
A — A + B). Also, having one of the 
operands in a rapidly accessible general- 
purpose register facilitates the use of inter- 
mediate results generated during a 
calculation. 



The majority of operations deal with byte, 
word, or long-word operands, thereby pro- 
viding a high degree of regularity. Also 
included in the instruction set are compact, 
one-word instructions for the most frequently 
used operations, such as branching short 
distances in a program. 

The instruction set contains some notable 
additions to the standard repertoire of earlier 
microprocessors. The Load and Exchange 
group of instructions has been expanded to 
support operating system functions and con- 
version of existing microprocessor programs. 
The usual arithmetic instructions can now deal 
with higher-precision operands, while hard- 
ware multiply and divide instructions have also 
been added. The Bit Manipulation instructions 
can use calculated values to specify the bit 
position within a byte or word as well as to 
specify the position statically in the instruc- 
tion. The Rotate and Shift instructions are con- 
siderably more flexible than those in previous 
microprocessors. The String instructions are 
useful in translating between different char- 
acter codes. Multiple-processor configurations 
are supported by special instructions. 

1.3.3 Data Types. Many data types are sup- 
ported by the Z8000 architecture. A data type 
is supported when it has a hardware represen- 
tation and instructions which directly apply to 
it. New data types can always be simulated in 
terms of basic data types, but hardware sup- 
port provides faster and more convenient 
operations. The basic data type is the byte, 
which is also the basic addressable element. 
The architecture also supports the following 
data types: words (16 bits), long words (32 
bits), byte strings, and word strings. In 
addition, bits are fully supported and 
addressed by number within a byte or word. 
BCD digits are supported and represented as 
two 4-bit digits in a byte. Arrays are supported 
by the Indexed addressing mode (see 1.3.4 
and Chapter 5). Stacks are supported by the 
instruction set and by an external device (the 
Memory Management Unit, MMU) available 
with the Z8001. 

1.3.4 Addressing Modes. The addressing 
mode, which is the way an operand is speci- 
fied in an instruction, determines how an 
address is generated. The Z8000 CPU offers 
eight addressing modes. Together with the 
large number of instructions and data types, 
they improve the processing power of the 
CPU. The addressing modes are Register, 
Immediate, Indirect Register, Direct Address, 
Index, Relative Address, Base Address, and 
Base Index. Several other addressing modes 
are implied by specific instructions, including 
autoincrement. The first five modes listed 
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1.3 Architec- above are basic addressing modes that are 
tural Features used most frequently and apply to most 
(Continued) instructions having more than one addressing 
mode. (In the Z8002, Base Address and Index 
modes are identical, and in the Z8001, Base 
Addressing capabilites can be simulated with 
all instructions, using Based Addressing or the 
Memory Management Unit and the Direct or 
Indexed Addressing mode.) 

1.3.5 Multiple Memory Address Spaces. The 

Z8000 CPU facilitates the use of multiple 
address spaces. When the Z8000 CPU 
generates an address, it also outputs signals 
indicating the particular internal activity which 
led to the memory request: instruction fetch, 
operand reference, or stack reference. This 
information can be used in two ways: to 
increase the memory space available to the 
processor (for example, by putting programs in 
one space and data in another); or to protect 
portions of the memory and allow only certain 
types of accesses (for example, by allowing 
only instruction fetches from an area desig- 
nated to contain proprietary software). The 
Memory Management Unit (MMU) has been 
designed to provide precisely these kinds of 
protection features by using the CPU- 
generated status information. 

1.3.6 System/Normal Mode of Operation. 

The Z8000 CPU can run in either system mode 
or normal mode. In system mode, all of the 
instructions can be executed and all of the 
CPU registers can be accessed. This mode is 
intended for use by programs performing 
operating system functions. In normal mode, 
some instructions may not be executed (e.g., 
I/O operations) , and the control registers of 
the CPU are inaccessible. In general, this 
mode of operation is intended for use by appli- 
cation programs. This separation of CPU 
resources promotes the integrity of the system, 
since programs operating in normal mode can- 
not access those aspects of the CPU which deal 
with time dependent or system- interface 
events. 

Programs executing in normal mode which 
have errors can always reproduce those errors 
for debugging purposes simply by re-exe- 
cuting the program with its original data. Pro- 
grams using facilities available only in system 
mode may have errors due to timing consider- 
ations (e.g. based upon the frequency of disk 
requests and disk arm-position) that are harder 
to debug because these errors are not easily 
reproduced. Thus, the preferred method of 
program development is to partition the task 
into a portion which can be performed without 
those resources accessible only in system mode 
(which will usually be the bulk of the task) and 
a portion requiring system mode resources. 
The classic example of this partitioning comes 
from current minicomputer and mainframe 
systems: the operating system runs in system 



mode and the individual users write their pro- 
grams to run in normal mode. 

To further support the system/normal mode 
dichotomy, there are two copies of the stack 
pointer — one for a system mode stack and 
another for a normal mode stack. These two 
stacks facilitate the task switching involved 
when interrupts or traps occur. To insure that 
the normal stack is free of system information, 
the information saved on the occurrence of 
interrupts or traps is always pushed on to the 
system stack before the new program status is 
loaded. 

1.3.7 Separate I/O Address Spaces. The 

Z8000 Architecture distinguishes between 
memory and I/O spaces and thus requires 
specific I/O instructions. This architectural 
separation allows better protection and has 
more potential for extension. The use of 
separate I/O spaces also conserves the limited 
Z8002 data memory space. There are in fact 
two separate I/O address spaces: standard I/O 
and special I/O. The main advantage of these 
two spaces is to provide for two types of 
peripheral support chips — standard I/O per- 
ipherals and special I/O peripherals — devices 
such as the Z8010 Memory Management Unit 
that do not respond to standard I/O com- 
mands, but do respond to special I/O com- 
mands. A second advantage of these two 
spaces is that they allow 8-bit peripherals to 
attach to the low-order eight bits (standard 
I/O) or to the high-order eight bits (special 
I/O) of the processor Address/Data bus. 

The increased speed requirements of future 
microprocessors are likely to be achieved by 
tailoring memory and I/O references to their 
respective, characteristic reference patterns 
and by using simultaneous I/O and memory 
referencing. These future possibilities require 
an architectural separation today. Memory- 
mapped I/O is still possible, but loss of protec- 
tion and lack of expandability are severe 
problems. 

1.3.8 Interrupt Structure. The sophisticated 
interrupt structure of the Z8000 allows the pro- 
cessor to continue performing useful work 
while waiting for peripheral events to occur. 
The elimination of periodic polling and idling 
loops (typically used to determine when a 
device is ready to transmit data) increases the 
throughput of the system. The CPU supports 
three types of interrupts. A non-maskable 
interrupt represents a catastrophic event which 
requires immediate handling to preserve 
system integrity. In addition, there are two 
types of maskable interrupts: non-vectored 
interrupts and vectored interrupts. The latter 
provides an automatic call to separate inter- 
rupt processing routines for each peripheral, 
depending on the vector presented by the 
peripheral to the Z8000. 
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1.3 Architec- The Z8000 has implemented a priority system 
tural Feotures for handUng interrupts. Vectored interrupts 
(Continued) have higher priority than non- vectored inter- 
rupts. This priority scheme allows the efficient 
control of many peripheral devices in a Z8000 
system. 

An interrupt causes information relating to 
the currently executing program (program 
status) to be saved on a special system stack 
with a code describing the reason for the 
switch. This allows recursive task switches to 
occur while leaving the normal stack undis- 
turbed by system information. The program 
state to handle the interrupt (new program 
status) is loaded from a special area in 
memory, the program status area, designated 
by a pointer resident in the CPU. 

The use of the stack and of a pointer to the 
program status area is a specific choice made 
to allow architectural compatibility if new 
interrupts or traps are added to the 
architecture. 

1.3.9 Multi-Processing. The increase in micro- 
processor computing power that the Z8000 
represents makes simple the design of 
distributed processing systems having many 
low- cost microprocessors running dedicated 
processes. 

The Z8000 provides some basic mechanisms 
that allow the sharing of address spaces among 
different microprocessors. Large segmented 
address spaces and the support for external 
memory management make this possible. Also, 
a resource request bus is provided which, in 
conjunction with software, provides the exclu- 
sive use of shared critical resources. These 
mechanisms, and new peripherals such as the 
Z-FIO, have been designed to allow easy asyn- 
chronous communication between different 
CPUs. 

1.3.10 Large Address Space for the Z8001. 

For many applications, a basic address space 
of 64K bytes is insufficient. A large address 
space increases the range of applications of a 
system by. permitting large, complex programs 
and data sets to reside in memory rather than 
be partitioned and swapped into a small 
memory as needed. A large address space 
greatly simplifies program and data manage- 
ment. In addition, large address spaces and 
memories reduce the need for minimizing pro- 
gram size and permit the use of higher level 
languages. The segmented version of the 
Z8000 generates 23-bit addresses, for a basic 
address space of 8 megabytes (8M or 8,388, 
608 bytes). 

1.3.11 Segmented Addressing of the Z8001. 

The segmented version of the Z8000 CPU 
divides its 23-bit addresses into a 7-bit seg- 
ment number and a 16-bit segment offset. The 
segment number serves as a logical name of a 
segment; it is not altered by the effective 



address calculation (by indexing, for exam- 
ple). This corresponds to the way memory is 
typically used by a program — one portion of 
the memory is set aside to hold instructions, 
another for data. In a segmented address 
space, the instructions could reside in one seg- 
ment (or several different modules in different 
segments), and each data set could reside in a 
separate segment. One advantage of segmenta- 
tion is that it speeds up address calculation 
and relocation. Thus, segmentation allows the 
use of slower memories than linear addressing 
schemes allow. In addition, segments provide 
a convenient way of partitioning memory so 
that each partition is given particular access 
attributes (for example, read-only). The Z8000 
approach to segmentation (simultaneous access 
to a large number of segments) is necessary if 
all the advantages of segmentation are to be 
realized. A system capable of directly access- 
ing only, say, four segments would lack the 
needed flexibility and would be constrained by 
address space limitations. 

1.3.12 Memory Management. Memory 
management consists primarily of dynamic 
relocation, protection, and sharing of memory. 
It offers the following advantages: providing a 
logical structure to the memory space that is 
independent of the actual physical location of 
data, protecting the user from inadvertent 
mistakes such as attempting to execute data, 
preventing unauthorized access to memory 
resources or data, and protecting the 
operating system from disruption by the users. 

The addresses manipulated by the program- 
mer, used by instructions, and output by the 
segmented Z8000 CPU are called logical 
addresses. The external memory management 
system takes the logical addresses and trans- 
forms them into physical addresses required 
for accessing the memory. This address trans- 
formation process is called relocation, which 
makes user software independent of the physi- 
cal memory. Thus, the user is freed from 
specifying where information is actually 
located in the physical memory. 

The segmented Z8000 CPU supports memory 
management both with segmented addressing 
and with program-status information. A seg- 
mented addressing space allows individual 
segments to be treated differently. 

Program status information generated by the 
CPU permits an external memory management 
device to monitor the intended use of each 
memory access. Thus, illegal types of access 
can be suppressed and memory segments pro- 
tected from unintended or unwanted modes of 
use. For example, system tables could be pro- 
tected from direct user access. This added pro- 
tection capability becomes more important as 
microprocessors are applied to large, complex 
tasks. 
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1.4 Benefits of The features of the Z8000 Architecture com- 
the Architec- bine to provide several significant benefits: 
ture improvements in code density, compiler effi- 

ciency, operating system support, and support 
for high level data structures. 

1.4.1 Code Density. Code density affects both 
processor speed and memory utilization. Code 
compaction saves memory space — an especial- 
ly important factor in smaller systems — and 
improves processor speed by reducing the 
number of instruction words that must be 
fetched and decoded. The Z8000 offers several 
advantages with respect to code density. The 
most frequently used instructions are encoded 
in single- word formats. Fewer instructions are 
needed to accomplish a given task and a con- 
sistent and regular architecture further 
reduces the number of instructions required. 

Code density is achieved in part by the use 
of special "short" formats for certain instruc- 
tions which are shown by statistical analysis to 
be most frequently used by assemblers. A 
"short offset" mechanism has also been provid- 
ed to allow a 2-word segmented address to be 
reduced to a single word; this format may be 
used by assemblers and compilers. 

The largest reduction in program size and 
increase in speed results from the consistent 
and regular structure of the architecture and 
from the more powerful instruction set — factors 
that substantially reduce the number of 
instructions required for a task. The architec- 
ture is more regular relative to preceding 
microprocessors because its registers, address 
modes, and data types can be used in a more 
orderly fashion. Any general-purpose register 
except RO can be specified as an acculumator, 
index register, or base register. With a few 
exceptions, all basic addressing modes can be 
used with all instructions, as can the various 
data types. 

General-purpose registers do not have to be 
changed as often as registers dedicated to a 
specific purpose. This reduces program size, 
since frequent load and store operations are 
not required. 

1 .4.2 Compiler Efficiency. For microprocessor 
users, the transition from assembly language to 
high-level languages allows greater freedom 
from architectural dependency and improves 
ease of programming. However, rather than 
adapt the architecture to a particular high- 
level language, the Z8000 was designed as a 
general-purpose microprocessor. (Tailoring a 
processor for efficiency in one language often 
leads to inefficiency in unrelated languages.) 
For the ZBOOO, language support has been pro- 
vided through the inclusion of features 
designed to minimize typical compilation and 
code-generation problems. Among these 
features is the regularity of the ZBOOO address- 



ing modes and data types. Access to 
parameters and local variables on the pro- 
cedure stack is supported by the "Index With 
Short Offset" addressing mode, as well as the 
Base Address and Base Index addressing 
modes. In addition, address arithmetic is aided 
by the Increment and Decrement instructions. 
Testing of data, logical evaluation, initializa- 
tion, and comparison of data are made possi- 
ble by the instructions Test, Test Condition 
Codes, Load Immediate Into Memory, and 
Compare Immediate With Memory. Since com- 
pilers and assemblers frequently manipulate 
character strings, the instructions Translate, 
Translate And Test, Block Compare, and Com- 
pare String all result in dramatic speed 
improvements over software simulations of 
these important tasks. In addition, any register 
except RO can be used as a stack pointer by 
the Push and Pop instructions. 

1.4.3 Operating System Support. Interrupt 
and task-switching features are included to 
improve operating system implementations. 
The memory- management and compiler- 
support features are also quite important. 

The interrupt structure has three levels: non- 
maskable, non-vectored, and vectored. When 
an interrupt occurs, the program status is 
saved on the stack with an indication of the 
reason for this state-switching before a new 
program status is loaded from a special area of 
memory. The program status consists of the 
flag register, the control bits, and the program 
counter. The reason for the occurrence is 
encoded in a vector that is read from the sys- 
tem bus and saved on the stack. In the case of 
a vectored interrupt, the vector also deter- 
mines a jump table address that points to the 
interrupt processing routine. 

The inclusion of system and normal modes 
improves operating system organization. In the 
system mode, all operations are allowed; in the 
normal mode, certain system instructions are 
prohibited. The System Call instruction allows 
a controlled switch of mode, and the imple- 
mentation of traps enforces these restrictions. 

Traps result in the same type of program 
status-saving as interrupts: in both cases, the 
information saved is pushed on to a system 
stack that keeps the normal stack undisturbed. 
The Load Multiple instruction allows the con- 
tents of registers to be saved efficiently in 
memory or on the stack. Running programs 
can cause program status changes under 
direct software control with the Load Program 
Status instruction. 

Finally, exclusion and serialization can be 
achieved with the "atomic" Test And Set 
instruction that synchronizes asynchronous 
cooperating processes. 
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1.4 Benefit of 1.4.4 Support for Many Types of Data Struc- 
the Architec- tures. A data structure is a logical organiza- 
ture tion of primitive elements (byte, word, etc-) 

(Continued) whose format and access conventions are well- 
defined. Common data structures include 
arrays, lists, stacks, and strings. Since data 
structures are high-level constructs frequently 
used in programming, processor performance 
is significantly enchanced if the CPU provides 
mechanisms for efficiently manipulating them. 
The Z8000 offers such mechanisms. 

In many applications, one of the most fre- 
quently encountered data structures is the 
array. Arrays are supported in the Z8000 by 
the index and the Base Index addressing mode 
and by segmented addressing. The Base Index 
addressing mode allows the use of pointers into 
an array (i.e., offsets from the array's starting 
address) . Segmented addressing allows an 
array to be assigned to one segment, which 
can be referenced simply by segment number. 

Lists occur more frequently than arrays in 
business applications and in general data pro- 
cessing. Lists are supported by Indirect Reg- 
ister and Base Address addressing modes. The 
Base Index addressing mode is also useful for 
more complex lists. 

Stacks are used in all applications for nest- 
ing of routines, block structured languages, 
and interrupt handling. Stacks are supported 
by the Push and Pop instructions, and multiple 
stacks may be implemented based on the 
general-purpose registers of the Z8000. In 



addition, two hardware stack pointers are used 
to assign separate stacks to system and normal, 
operating modes, thereby further supporting 
the separation of system and normal operating 
environments discussed earlier. 

Byte and word strings are supported by the 
Translate and Translate And Test instructions. 
Decimal strings use the Decimal Adjust 
instruction to do decimal arithmetic on strings 
of BCD data, packed two characters per byte. 
The Rotate Digit instructions also manipulate 
4-bit data. 

1.4.5 Two CPU Versions: Z8001 and Z8002. 

The ZBOOO CPU is offered in two versions: the 
ZBOOl 48-pin segmented CPU and the Z8002 
40-pin nonsegmented CPU. The main differ- 
ence between the two is addressing range. The 
Z8001 can directly address 8M bytes of 
memory; the Z8002 directly addresses 64K 
bytes. The Z8001 has a non- segmented mode of 
operation which permits it to execute programs 
written for the Z8002. 

Not all applications require the large 
address space of the Z8001; for these appli- 
cations the Z8002 is recommended. Moreover, 
many multiple-processor systems can be imple- 
mented with one Z8001 and several Z8002s, 
instead of exclusively using Z8001s. Since the 
same assembler generates code for both CPUs, 
users can buy only the power they require 
without having to worry about software incom- 
patibility between processors. 



1.5 Extended The Z8000 architecture has a mechanism for 
Instruction extending the basic instruction set through the 
Facility use of external devices. Special opcodes have 

been set aside to implement this feature. When 
the CPU encounters an instruction with these 
opcodes in its instruction stream, it will per- 
form any indicated address calculation and 
data transfer; otherwise, it will treat the 
"extended instruction" as being executed by 
the external device. Fields have been set aside 
in these extended instructions which can be 
interpreted by external devices (Extended Pro- 



cessing Units — EPUs) as opcodes. Thus, by 
using appropriate EPUs, the instruction set of 
the Z8000 can be extended to include special- 
ized instructions. 

In general, an EPU is dedicated to perform- 
ing complex and time-consuming tasks in 
order to unburden the CPU. Typical tasks suit- 
able for specialized EPUs include floating- 
point arithmetic, data base search and main- 
tenance operations, network interfaces, 
graphics support operations — a complete list 
would include most areas of computing. 



1.6 Summary The architectural sophistication of the Z8000 
microprocessor is on a level comparable with 
that of the minicomputer. Features such as 
large address spaces, multiple memory spaces, 
segmented addresses, and support for multiple 
processors are beyond the capabilities of the 
traditional microprocessor. The benefits of this 



architecture — code density, compiler support, 
and operating system support — greatly 
enhance the power and versatility of the CPU. 
The CPU features that support an external 
memory management system also enhance the 
CPU's applicability to large system 
environments. 
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Chapter 2 
Architecture 



2.1 Intro- This chapter provides an overview of the 

duction Z8000 CPU architecture. The basic hardware, 

operating modes and instruction set are all 
described. Differences between the two ver- 
sions of the Z8000 (the nonsegmented Z8002 



and the segmented ZBOOl) are noted where 
appropriate. Most of the subjects covered here 
are also treated with greater detail in later 
chapters of the manual. 



2.2 General Figure 2. 1 contains a block diagram that 

Organization shows the major elements of the ZBOOO CPU, 
namely. 

■ A 16-bit internal data bus, which is used to 
move addresses and data within the CPU. 

■ A Z-Bus interface, which controls the inter- 
action of the CPU with the outside world. 

■ A set of 16 general-purpose registers, which 
is used to contain addresses and data. 

■ Four special-purpose registers, which con- 
trol the CPU operation. 

■ An Arithmetic and Logic Unit, which is 
used for manipulating data and generating 
addresses. 

■ An instruction execution control, which 
fetches and executes ZBOOO instructions. 



■ An exception-handling control, which pro- 
cesses interrupts and traps. 

■ A refresh control, which generates memory 
refresh cycles. 

Each of these elements is explained in the 
following sections. All of the elements are 
common to both the Z8001 CPU and the Z8002 
CPU. The differences between the two versions 
of the Z8000 are derived from the number of 
bits in the addresses they generate. The Z8002 
always generates a 16-bit linear address, while 
the Z8001 always generates a 23-bit segmented 
address (that is, an address composed of a 
7-bit segment number and a 16-bit offset). 
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Figure 2-1. Z8000 CPU Functional Block Diagram 
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2.2 General Figure 2.2 gives a system- level view of the 

Organization Z8000. It is important to realize that the Z8000 
(Continued) CPU comes with a whole family of support 
components. The Z8000 Family has been 
designed to allow the easy implementation of 
powerful systems. The major elements of such 
a system might include: 

■ The Z-Bus, a multiplexed address/data 
shared bus that links the components of the 
system. 

■ A Z8001 or Z8002 CPU. 

■ One or more Extended Processing Units 
(FPUs), which are dedicated to performing 
specialized, time-consuming tasks. 

■ A memory sub-system, which in Z8001 
systems can include one or more Memory 



Management Units (MMUs) that offer sophis- 
ticated memory allocation and protection 
features. 

One or more Direct Memory Access (DMA) 
controllers for high-speed data transfers. 

A large number of possible peripheral 
devices interfaced to the Z-Bus through 
Universal Peripheral Controllers (UPCs), 
Serial Communication Controllers (SCCs), 
Counter-Timer and Parallel I/O Controllers 
(CIOs) or other Z-Bus peripheral 
controllers. 

One or more FIFO I/O Interface Units 
(FIOs) for elastic buffering between the 
CPU and another device, such as another 
CPU in a distributed processing system. 
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Figure 2-2. Z8000 System Configuration 
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2.3 Hardware Figure 2.3 shows the Z8000 pins grouped 
Interface according to function. The Z8001 is packaged 

in a 48-pin DIP and the Z8002 is packaged in a 
40-pin DIP. The eight additional pins on the 
Z8001 are the seven segment-number hnes and 
the segment trap. Except for those eight, all 
pins on the two CPU versions are identical. 

The Z8000 is a Z-Bus CPU; thus, activity on 
the pins is governed by the Z-Bus protocols 
(see The Z-Bus Summary). These protocols 
specify two types of activities: transactions, 
which cover all data movement (such as 
memory references or I/O operations), and 
requests, which cover interrupts and requests 
for bus or resource control. The following is a 
brief overview of the Z8000 pin functions; com- 
plete descriptions are found in Chapter 9. 

2.3.1 Address/Data Lines. These 16 lines 
alternately carry addresses and data. The 
addresses may be those of memory locations or 
I/O ports. The bus timing signal lines 
described below indicate what kind of informa- 
tion the Address/Data lines are carrying. 

2.3.2 Segment Number (Z8001 only). These 
seven lines encode the addresses of up to 128 
relocatable memory segments. The segment 
signals become valid before the address offset 
signals, thus supporting address relocation by 
the memory managment system. 

2.3.3 Bus Timing. These three lines include 
Address Strobe ( AS), Da ta Strobe (DS) and 
Memory Request (MREQ). They are used to 
signal the beginning of a bus transaction and 
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Figure 2-3. Z8000 Pin Functions 

to determine when the multiplexed Address/ 
Data Bus holds addresses or data. The Memory 
Request signal can be used to time control 
signals to a memory system. 
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2.3.4 Status. These lines function to indicate 
the kind of transaction on the bus (STQ-ST3), 
whether it is a read or write (R/W, where High 
is Read and Low is Write), whether it is on 
byte or word data (B/W, High = byte. 
Low = word), and whether the CPU is 
operating in normal mode or system mode 
(N/S, High = normal. Low = system). The 
STQ-ST3 lines also encode additional 
characteristics of the bus transactions, as Table 
2.1 shows. The availability of status information 
defining the type of bus transaction in advance 
of data transmission allows bidirectional 
drivers and other external hardware elements 
to be enabled before data is transferred. 



Table 2.1 Status Line Codes 
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2.3 Hordware 2.3.5 CPU Control. These inputs allow exter- 
Interface nal device s to delay the operation of the CPU. 

(Continued) The WAIT line, when active (Low), causes the 
CPU to idle in the middle of a bus transa ction, 
taking extra clock cycles until the WAIT line 
goes inactive; it is typically used by memory or 
I/O peripherals which o perate m ore slowly 
than the CPU. The Stop (STOP) line halts 
internal CPU operation when the first word of 
an instruction (or the second word of an EPA 
instruction) has been fetched. This signal is 
useful for single-step instruction execution dur- 
ing debugging operations and for enabling 
Extended Processing Units to halt the CPU 
temporarily. 

2.3.6 Bus Control. These lines provide the 
means for other devices, such as direct 
memory access (DMA) controllers, to gain 
exclusive use of the system bus, i.e., the signal 
lines that are common to several devices in a 
system. The external device req uesting co ntrol 
of the bus inputs a bus request (BUSREQ); the 
CPU respo nds with a bus acknowledge 
(BUSACK) after three-starting, or electrically 
neutralizing, the Address/Data Bus, Bus Tim- 
ing lines, Status lines, and Control lines. The 
Z-Bus allows a daisy chain to be used to 



enforce a priority among several external 
devices. 

2.3.7 Interrupts. Three interrupt in puts a re 
provided: non-maskable interrupts (NMI), vec- 
tored inter rupts (VI) and non- vectored inter- 
rupts (NVI). These permit external devices to 
suspend the CPU's execution of its current 
program and begin executing an interrupt ser- 
vice routine. 

2.3.8 Segment Trap Request (Z8001 
only). This input to the CPU is used by an 
external memory- management system to indi- 
cate that an illegal memory access has been 
attempted. 

2.3.9 Multi-Micro Control. The Multi-Micro In 
(MI) and Multi-Micro Out (MO) lines are used 
in conjunction with instructions such as MSET 
and MREQ to coordinate multiple-CPU sys- 
tems. They allow exclusive use by one CPU of 
a shared resource in a multiple-CPU system. 

2.3.10 System Inputs. The four inputs shown 
at the bottom of Figure 3 include -(-5 V power, 
ground, a single-phase clock signal and a CPU 
reset. The reset function is described in 
Chapter 7. 



2.4 Timing Figure 2.4 shows the three basic timing 

periods of the Z8000: a clock cycle, a bus 
transaction, and a machine cycle. A clock 
cycle (sometimes called a T-state) is one cycle 
of the CPU clock, starting with a rising edge. 
A bus transaction covers a single data move- 
ment on the CPU bus and will last for three or 
more clock cycles, starting with a falling edge 



of AS and ending with a rising edge of DS. A 
machine cycle covers one basic CPU operation 
and always starts with a bus transaction. A 
machine cycle can extend beyond the end of a 
transaction by an unlimited number of clock 
cycles. Appendix A contains a complete 
description of Z8000 timing. 
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Figure 2-4. Basic Timing Periods 



2.5 Address The Z8000 supports two main address 

Spaces spaces corresponding to the two different kinds 

of locations that can be addressed: 

■ Memory Address Space. This consists of the 
addresses of all locations in the main 
memory of the computer system. 

■ I/O Address Space. This consists of the 
addresses of all I/O ports through which 
peripheral devices are accessed. 

For more information on address spaces, con- 
sult Chapter 3. 



2.5.1 Memory Address Space. Memory 
address space can be further subdivided into 
Program Memory address space. Data Memory 
address space, and Stack Memory address 
space, each for both normal and system 
modes. 

The particular space addressed is deter- 
mined by the external circuitry from the code 
appearing at the CPU's output status pins 
(STo-ST3)_and the state of the Normal/System 
signal (N/S pin). Data memory reference, stack 
memory reference, and program memory 
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2.5 Address reference each correspond to a different status 
Spaces code at the ST0-ST3 outputs, allowing three 

(Continued) address spaces to be distinguished for each of 
two operating modes, giving six address 
spaces in all. Each of the six address spaces 
has a range as great as the addressing ability 
of the processor. For the nonsegmented Z8002, 
each address space can have up to 64K bytes, 
giving a potential total system capacity of 384K 
bytes of directly addressable memory. The 
segmented Z8001, on the other hand, provides 
up to 48M bytes of directly addressable mem- 
ory due to the 23-bit segmented addresses. 
Segmentation is a means of partitioning 
memory into variable-size segments so that a 
variety of useful functions may be imple- 
mented, including: 

■ Protection mechanisms that prevent a user 
from referencing data belonging to others, 
attempting to modify read-only data or over- 
flowing a stack. 

■ Virtual memory, which permits a user to 
write functioning programs under the 
assumption that the system contains more 
memory than is actually available. 

■ Dynamic relocating which allows the place- 
ment of blocks of data in physical memory 



independently of user addresses, allowing 
better management of the memory resources 
and sharing of data and programs. 

The signals provided on the segmented 
Z8001 CPU assist in implementing these 
features, although additional software and 
external circuitry (such as the Z8010 MMU) are 
generally required to take full advantage of 
them. Chapter 3 contains an extensive discus- 
sion of segmentation and the Z8001. 

2.5.2 I/O Address Space. I/O addresses are 
represented as 16-bit words for both the Z8001 
and Z8002. 

There are two I/O address spaces. Standard 
I/O and Special I/O, which are both separate 
from the memory address space. Each I/O 
space is accessed through a separate set of I/O 
instructions, which can be executed only when 
the CPU is operating in system mode. 

Standard I/O instructions transfer data 
between the CPU and peripherals and Special 
I/O instructions transfer data to or from exter- 
nal CPU support circuits such as the Z8010 
MMU. Access to Standard or Special I/O 
space is distinguished by the status lines 
(ST0-ST3). 



2.6 General- The Z8000 CPU contains 16 general-purpose 
Purpose registers, each 16 bits wide. Any general- 

Registers purpose register can be used for any instruc- 

tion operand (except for minor exceptions 
described at the beginning of Chapter 5). 

Figure 2.5 shows these general-purpose reg- 
isters. They allow data formats ranging from 
bytes to quadruple words. The word registers 
are specified in assembly- language statements 
as RO through R15. Sixteen byte registers. 



RH0-RL7, which may be used as accumulators, 
overlap the first eight word registers. Register 
grouping for larger operands includes eight 
double-word (32-bit) registers, RR0-RR14, and 
four quad-word registers, RQ0-RQ12, which 
are used by a few instructions such as Mul- 
tiply, Divide, and Extend Sign. 

As Figure 2.5 illustrates, the CPU has two 
hardware stack pointers, one dedicated to each 
of the two basic operating modes, system and 
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Figure 2-5a. Z800I General-Purpose Registers 
(Register Address Space) 



Figure 2-5b. Z8002 General-Purpose Registers 
(Registers Address Space) 
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2.6 General- normal. The segmented Z8001 uses a two-word 
Purpose stack pointer for each mode (Ri4'/R15' or 

Registers R14/R15), whereas the nonsegmented Z8002 

(Continued) uses only one word for each mode (R15' 
orRlS). 

The system stack pointer is used for saving 
status information when an interrupt or trap 
occurs and for supporting calls in system 



mode. The normal stack pointer is used for 
subroutine calls in user programs. In normal- 
mode operation only the normal stack pointer 
is accessible. In system mode, the normal stack 
pointer can be directly accessed as a special 
control register. The normal mode stack 
pointer can be assessed as a special control 
register. 



2.7 Special- In addition to the general-purpose registers, 

Purpose there are special-purpose registers. These 

Registers include the Program Status registers, the Pro- 

gram Status Area Pointer, and the Refresh 
Counter; they are illustrated for both CPU ver- 
sions in Figure 2.6. Each register can be 
manipulated by software executing in system 
mode, and some are modified automatically by 
certain operations. 

2.7.1 Program Status Registers. These 
registers include the Flag and Control Word 
(FCW) and the Program Counter (PC). They 
are used to keep track of the state of an exe- 
cuting program. 

In the nonsegmented Z8002, the Program 
Status registers consist of two words: one each 
for the FCW and the PC. In the segmented 
Z8001, there are four words: one reserved 
word, one word for the FCW and two words for 
the segmented PC. 

The low-order byte of the Flag and Control 
Word (FCW) contains the six status flags, from 
which the condition codes used for control of 
program looping and branching are derived. 
The six flags are: 

Carry (C), which generally indicates a carry 
out of the high-order bit position of a register 
being used as an accumulator. 

Zero (Z), which is generally used to indicate 
that the result of an operation is zero. 

Sign (S), which is generally used to indicate 
that the result of an operation is a negative 
number. 
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Z8001 Program Status Registers 



Z8001 Program Status Area Pointer 



Parity/Overflow (P/V), which is generally used 
to indicate either even parity (after logical 
operations on byte operands) or overflow (after 
arithmetic operations) . 

Decimal-Adjust (D), which is used in BCD 
arithmetic to -indicate the type of instruction 
that was executed (addition or subtraction). 

Half Carry (H), which is used to convert the 
binary result of a previous decimal addition or 
subtraction into the correct decimal (BCD) 
result. 

Section 6.3 provides more detail on these 
flags. 

The control bits, which occupy the high- 
order byte of the FCW, are used to enable 
various interrupts or to control CPU operating 
modes. The control bits are: 

Non- Vectored Interrupt Enable (NVIE), Vec- 
tored Interrupt Enable (VIE). These bits deter- 
mine whether or not the CPU will accept non- 
vectored or vectored interrupts (see Section 
2.13). 

System/Normal Mode (S/N). When this bit is 
set to one, the CPU is operating in system 
mode; when cleared to zero, the CPU is in 
normal mode (see_Section 2.8). The CPU out- 
put status line (N/S pin) is the complement of 
this bit. 

Extended Processor Architecture (EPA) 
Mode. When this bit is set to one, it indicates 
that the system contains Extended Processing 
Units, and hence extended instructions 
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Z8002 Program Status Registers 
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Z8002 Program Status Area Pointer 
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Figure 2-6. CPU Special Registers 
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2.7 Special encountered in the CPU instruction stream are 

Purpose executed (see Section 2.12). When this bit is 

Registers cleared to zero, extended instructions are 

(Continued) trapped for software emulation. 

Segmentation Mode (SEG). This bit is imple- 
mented only in the Z8001; it is always cleared 
in the nonsegmented Z8002. When set to one, 
the CPU is operating in segmented mode, and 
when cleared to zero, the CPU is operating in 
nonsegmented mode (see Section 2.8). 

2.7.2 Program Status Area Pointer 
(PSAP). The Program Status Area Pointer 
points to an array of progam status values 
(FCWs and PCs) in main memory called the 
Program Status Area. New Program Status reg- 



ister values are fetched from this area when an 
interrupt or trap occurs. As shown in Figure 
2.6, the PSAP comprises either one word (non- 
segmented Z8002) or two words (segmented 
Z8001); for either configuration, the lower byte 
of the pointer must be zero. Refer to Chapter 7 
for more details about the Program Status Area 
and its layout. 

2.7.3 Refresh Counter. The CPU contains a 
programmable counter that can be used to 
refresh dynamic memory automatically. The 
refresh counter register consists of a 9-bit row 
counter, a 6-bit rate counter and an enable bit 
(Figure 2.6). Refer to Chapter 8 for details of 
the refresh mechanism. 



2.8 Instruction In the normal course of events, the Z8000 
Execution CPU will spend most of its time fetching 

instructions from memory and executing them. 

This process is called the running state of the 

CPU. The CPU also has two other states that it 

occasionally enters. 

Stop/Refresh State. This is really one state, 
although it may be entered in two different 
ways: either automatically for a per iodic 
memory refresh; or when the STOP line is acti- 
vated. In this state, program execution is 
temporarily suspended and the CPU makes use 
of the Refresh Counter to generate refreshes. 
For more information, consult Chapter 8. 

Bus-Disconnect State. This is the state the 
CPU enters when the DMA, or some other bus 
reguester, takes over the bus. Program execu- 
tion is suspended and the CPU disconnects 
itself from the bus. 

While the CPU is in the running state, it can 
either be handling interrupts or executing 



instructions. If it is executing instructions, the 
Z8000 can be in the system or normal execu- 
tion mode. In system mode, privileged instruc- 
tions (such as those which perform I/O) can be 
executed; in normal mode they cannot. This 
dichotomy allows the creation of operating 
system software, which controls CPU resources 
and is protected from application program 
action. 

In addition, the CPU will be in either seg- 
mented or nonsegmented mode. In segmented 
mode, which is available only on the Z8001, 
the program uses 23-bit segmented addresses 
for memory accesses; in nonsegmented mode, 
which is available on both CPUs, the program 
uses 16-bit nonsegmented addresses for mem- 
ory accesses. 

While executing instructions, the mode of 
the CPU is controlled by JDits in the FCW (Sec- 
tion 2.8). While handling interrupts, the CPU 
is always in system mode and, for the Z8001, in 
segmented mode. 



2.9 Instructions The Z8000 instruction set contains over 400 
different instructions which are formed by 
combining the 110 distinct instruction types 
(opcodes) with the various data types and 
addressing modes. The complete set is divided 
into the following groups: 

Load and Exchange for register-to-register 
and register-to-memory operations, including 
stack management. 

Arithmetic for arithmetic operations, including 
multiply and divide, on data in either registers 
or memory. Compare, increment, and decre- 
ment functions are included. 

Logical for Boolean operations on data in 
registers or memory. 

Program Control for program branching (con- 
ditional or unconditional), calls, and returns. 

Bit Manipulation for setting, resetting and 
testing individual bits of bytes or words in 
registers or memory. 



Rotate and Shift for bytes, words, or, for shifts 
only, long words within registers. 

Block Transfer and String Manipulation for 

automatic memory-to-memory transfers of data 
blocks or strings, including compare and 
translate functions. 

Input/Output for transfers of data between I/O 
ports and memory or registers. 

Extended for operations involving Extended 
Processing Units. 

CPU Control for accessing special registers, 
controlling the CPU operating state, synchro- 
nizing multiple-processor operation, enabling/ 
disabling interrupts, mode selection, and 
memory refresh. 

Chapter 6 contains details on the full instruc- 
tion set. 
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2.9 2.9.1 Instruction Formats. Formats of the 

Instructions instructions are shown in Figure 2.7. The two 
(Continued) most significant bits in the instruction word 

determine whether the compact instruction for- 
mat (A) or the general instruction format (B) is 
used. Compact formats encode the four most 
frequently used instructions into single words, 
thereby saving on instruction-memory usage 
and increasing execution speed. As long as 
the two most significant bits are not logic ones, 
the general format applies. In the general for- 
mat, the two most significant bits in conjunc- 
tion with the source-register field are sufficient 
for specifying any of the five main addressing 
modes. Source and destination fields are four 
bits wide for addressing the 16 general- 
purpose registers. 



COMPACT INSTRUCTION FORMAT 

LOAD IMMEDIATE BYTE 

n — r-*T — r-T — I — r- 



T I I — I — r 



ZD 



CALL RELATIVE 



CALR 1110 1 



JUMP RELATIVE 

I — I I I I — r-1 — I — r 
I 1 1 1 I cc I 



DJN2 II 1 1 1 



-1—1 — I — I I I 



GENERAL INSTRUCTION FORMAT (FIRST WORD) 
addressing 
mode 

BYTE OR I / I I 1 'I |,„| I ' 

VI^ORD I ^ I opcode |W| soui 



addressing 
mode 
/, , 



Note: W indicates Word (1) or Byte (0) 

Figure 2-7. Instruction Formats 



2.10 Data The Z8000 supports manipulation of eight 

Types data types. Five of these have fixed lengths; 

the other three have lengths that can vary 
dynamically. Each data type is supported by a 
number of instructions which operate upon it 
directly. These data types are: 

■ Bit 

■ Signed and unsigned byte, word, long 
word, or quadruple word binary integer 

■ Byte or word- length logical value 

■ Word (nonsegmented) or long word 
(segmented) address 



■ Unsigned byte decimal integer 

■ Dynamic- length string of byte data 

■ Dynamic- length string of word data 

■ Dynamic-length stack of word data 

Bits can be manipulated in registers or 
memory. Binary and decimal integers and 
logical values can be manipulated in registers 
only, although operands can be fetched direct- 
ly from memory. Addresses are manipulated 
only in registers, and strings and stacks are 
manipulated only in memory. 



2.11 The information included in Z8000 instruc- 

Addressing tions consists of the function to be performed. 
Modes the type and size of data elements to be 

manipulated, and the location of the data 
elements. Locations are designated using one 
of the following eight addressing modes: 

Register Mode. The data element is located in 
one of the 16 general-purpose registers. 

Immediate Mode. The data element is located 
in the instruction. 

Indirect Register Mode. The data element can 
be found in the location whose address is in a 
register. 

Direct Address Mode. The data element can 
be found in the location whose address is in 
the instruction. 

Index Mode. The data element can be found 



in the location whose address is the sum of the 
contents of a 16-bit index value in a register 
and an address in the instruction. 

Relative Address Mode. The data element can 
be found in the location whose address is the 
sum of the contents of the program counter 
and a 16-bit displacement in the instruction. 

Base Address Mode. The data element can be 
found in the location whose address is the sum 
of a base address in a register and a 16-bit 
displacement in the instruction. 

Base Index Mode. The data element can be 
found in the location whose address is the sum 
of a base address in one register and an index 
value in another register. 

Chapter 5 defines and illustrates the eight 
addressing modes. 



2.12 Extended An important feature of the Z8000 CPU 
Processing architecture is the Extended Processing 
Architecture Architecture (EPA) facility. This facility pro- 
vides a mechanism by which the basic instruc- 
tion set of the CPU can be extended via exter- 
nal devices, called Extended Processing Units 
(EPUs). A special set of instructions, called 
extended instructions, is used to control this 
feature. When the CPU encounters one of 



these extended instructions in its instruction 
stream, it will either trap to a software trap 
handler to process the instruction or it will 
perform the data transfer portion of the 
instruction (leaving the data manipulation part 
of the instruction to the EPU). Whether the 
CPU traps or transfers data depends on the 
setting of the EPA bit in the FCW. 
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2.12 Extended The underlying philosophy behind the EPA 
Processing feature is a view of the CPU as an instruction 
Architecture processor — the CPU fetches instructions, 
(Continued) fetches data associated with the instruction, 
performs the operations and stores the result. 
Extending the number of operations performed 
does not affect the instruction fetch and 
address calculation portion of the CPU activi- 
ty. The extended instructions exploit this 



feature — the CPU fetches the instruction and 
performs any address calculation that may be 
needed. It also generates the timing signals for 
the memory access if data must be transferred 
between memory and the extended processor. 
But the actual data manipulation is handled by 
the EPU. The Extended Processing Architec- 
ture is explained more fully in Chapter 4. 



2.13 Three events can alter the normal execu- 

Exceptions tion of a Z8000 program: hardware interrupts 

that occur when a peripheral device needs ser- 
vice, synchronous software traps that occur 
when an error condition arises, and system 
reset. Chapter 7 contains a detailed descrip- 
tion of exceptions and how they are handled. 
Interrupt requests and segmentation trap re- 
quests are accepted after the completion of the 
instruction execution during which they were 
made. At the end of the instruction execution, 
a spurious instruction fetch transaction is 
usually performed before the interrupt or 
acknowledge sequence begins, but the Pro- 
gram Counter is not affected by the spurious 
fetch. 

2.13.1 Reset. A system reset overrides all 
other operating conditions. It puts the CPU in 
a known state and then causes a new program 
status to be fetched from a reserved area of 
memory to reinitialize the Flag and Control 
Word (FCW) and the Program Counter (PC). 

2.13.2 Traps. Traps are synchronous events 
that are usually triggered by specific instruc- 
tions and recur each time the instruction is 
executed with the same set of data and the 
same process or state. The four kinds of traps 
are: 

Extended instruction attempted in non-EPA 
mode. The current instruction is an EPU 
instruction, but the system is not in EPA mode. 
This trap allows system software to either 
simulate instruction or abort the program. 

Privileged instruction attempted in normal 
mode. The current instruction is privileged 
(I/O for example), but the CPU is in normal 
mode. 

System Call (SC) instruction. This instruction 
provides a controlled access from normal-mode 
to system-mode operation. 

Segmentation violation (supplied by external 
circuit). A segmentation violation, such as 



using an offset larger than the defined length 
of the segment, can be made to cause an 
external memory management system to signal 
a segmentation trap. This can occur only with 
the segmented Z8001. 

2.13.3 Interrupts. Interrupts are asynchronous 
events typically triggered by peripheral 
devices needing attention. The three kinds of 
interrupts associated with the three interrupt 
lines of the CPU are: 

Non-maskable interrupts (NMI). These inter- 
rupts cannot be disabled and are usually 
reserved for critical external events that 
require immediate attention. 

Vectored interrupts (VI). These interrupts 
cause eight bits of the vector output by the 
interrupting device to be used to select a par- 
ticular interrupt service procedure to which 
the program automatically branches. 



Non-vectored interrupts (NVI). These inter- 
rupts are maskable interrupts which are all 
handled by the same interrupt procedure. 

2.13.4 Trap and Interrupt Service Pro- 
cedures. Interrupts and traps are handled 
similarly by the Z8000 CPU. The ZBOOO CPU 
automatically acknowledges interrupts and 
processes traps in system mode. In the case of 
the segmented ZBOOl, the CPU uses the 
segmented mode regardless of its mode at the 
time of interrupt or trap. The program status 
information in effect just prior to the interrupt 
or trap is pushed onto the system stack. An ad- 
ditional word, which serves as an identifier for 
the interrupt or trap, also is pushed onto the 
system stack, where it can be accessed by the 
interrupt or trap handler. The Program Status 
registers are loaded with new status informa- 
tion obtained from the Program Status Area of 
memory. Then control is transferred to the ser- 
vice procedure, whose address is now located 
in the Program Counter. For details of inter- 
rupt and trap handling, refer to Chapter 7. 
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Chapter 3 
Address Spaces 



3.1 Intro- Programs and data may be located in the 

duction main memory of the computer system or in 

peripheral devices. In either case, the location 
of the information must be specified by an 
address of some sort before that information 
can be accessed. A set of these addresses is 
called an address space. 

The Z8000 supports two different types of 
addresses and thus two categories of address 
spaces: 

■ Memory addresses, which specify locations 
in main memory. 

■ I/O addresses, which specify the ports 
through which peripheral devices are 
accessed. 



The CPU generates addresses during four 
types of operations: 

■ Instruction letches, described in Chapter 4. 

■ Operand letches and stores, described in 
Chapter 5. 

■ Exception processing, described in 
Chapter 7. 

■ Refreshes, described in Chapter 8. 

Timing information concerning addresses is 
described in Chapter 9. 



3.2 Types of Within the two general types of address 

Address spaces (memory and I/O), it is possible to dis- 

Spaces tinguish several subcategories. Figure 3.1 

shows the address spaces that are available on 
both the Z8001 and the Z8002. 

The difference between the Z8001 and the 
Z8002 lies not in the number and type of 
address spaces, but rather in the organization 
and maximum size of each space. For the 
Z8001, each of the six memory address spaces 
contains 8M byte addresses grouped into 128 
segments, for a total memory addressing capa- 
bility of 48M bytes.' For the Z8002, each mem- 
ory space is a homogeneous collection of 64K 
byte addresses. In both the Z800I and the 
Z8002, the I/O address spaces contain 64K port 
addresses. When an address is used to access 
data, the address spaces may be distinguished 
by the state of the status lines (ST0-ST3) (which 
is determined by the way the address was 
generated) and_by the value of the Normal/ 
System line (N/S) (which is determined by the 
state of the S/N bit in the FCW). 

■ Instruction Spacejstatus = 1100 or 1101), 
normal mode (N/S - 1) or system mode 
(N/S = 0). These spaces typically address 
memory that contains user programs (nor- 
mal) or system programs (system). 



Data Spaces (status = 1000 or 1010), nor- 
maI_mode (N/S = 1) or system mode 
(N/S = 0). These spaces may be used to 
address the data that user or system pro- 
grams operate on. 

Stack Spaces ^tatus = 1001 or 1011), nor- 
maljpode (N/S = 1) or system mode 
(N/S = 0). These spaces can be used to 
address the system and normal program 
stacks. 

Standard I/O Space (status = 0010). This 
space addresses all the I/O ports that are 
used for Z8000 peripherals. 

Special I/O Space (status = 0011). This 
space addresses ports in CPU support chips 
(such as the Z8010 Memory Management 
Unit). 



MEMORY ADDRESS SPACES 


SYSTEM MODE 


NORMAL MODE 


INSTRUCTIONS 
DATA 
STACK 


INSTRUCTIONS 
DATA 
STACK 



I/O ADDRESS SPACES 



SYSTEM MODE 



STANDARD I/O 
SPECIAL I/O 



Figure 3-1. Address Spaces on the Z8001 and Z8002 



3.3 I/O All I/O addresses are represented by 16-bit 

Address words. Each of the ports addressed is either 

Spaces eight or 16 bits wide. Transfer to or from 16-bit 

ports always involves word data and, for 8-bit 

ports, byte data. 



The address of a 16-bit port may be even or 
odd for both address spaces. In standard I/O 
space, byte ports must have an odd address; in 
special I/O space, byte ports must have an 
even address. 
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3.4 Memory Each memory address space in the Z8002, or 

Address each segment in each memory address space 

Spaces on the Z8001, can be viewed as addressing a 

string of 64K bytes numbered consecutively in 
ascending order. The 8-bit byte is the basic 
addressable element in Z8000 memory address 
spaces. However, there are three other 
addressable data elements: 

■ Bits, in either bytes or words. 

■ 16-bit words. 

■ 32-bit long words. 

3.4.1 Addressable Data Elements. The nature 
of the data element being addressed depends 
on the instruction being executed. As Chapter 
6 explains in detail, different assembler 
mnemonics are used for addressing bytes, 
words, and long words. Moreover, only certain 
instructions can address bits. 

A bit can be addressed by specifying a byte 
or word address and the number of the bit 
within the byte (0-7) or word (0-15). Bits are 
numbered right-to-left, from the least to the 



most significant. This is consistent with the 
convention that bit n corresponds to position 
2n in the conventional representation of binary 
numbers (see Figure 3.2). 

The address of a data type longer than one 
byte (word or long word) is the same as the 
address of the byte with the lowest memory 
address within the word or long word (Figure 
3.2). This is the leftmost, highest- order, or 
most significant byte of the word or long word. 

Word or long word addresses are always 
even-numbered. Low bytes of words are stored 
at odd-numbered memory locations and high 
bytes at even-numbered locations. Byte 
addresses can be either even- or odd- 
numbered. 

Certain memory locations are reserved for 
system- reset handling. These are described 
fully in Chapter 7. Except for these reserved 
locations, there are no memory addresses 
specifically designated for a particular 
purpose. 
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BITS IN A WORD 



LONG WORD 



Figure 3-2. Addressable Data Elements 



3.4.2 Segmented and Non-Segmented 
Addresses. The two versions of the Z8000 CPU 
generate two kinds of addresses with different 
lengths. The Z8002 generates a 16-bit address 
specifying one of 64K bytes. The Z8001 gener- 
ates a 23-bit segmented address. A segmented 
address consists of a 7-bit segment number, 
which specifies one of 128 segments, and a 
16-bit offset, which specifies one of up to 64K 
bytes in the segment. Each segment is an inde- 
pendent collection of bytes; thus, instructions 
and multiple byte data elements cannot cross 
segment boundaries. Some of the advantages 
of address segmentation are outlined in Sec- 
tion 3.4.3. 

Figure 3.3 shows the format of segmented 
and nonsegmented addresses. Nonsegmented 
addresses are 16 bits long and thus can be 
stored in word registers (Rn) or in memory as 
word-length addressable elements. The 23-bit 
segmented addresses are embedded in a 32-bit 



long word and thus can be stored in a long 
word register (RRn) or a long word memory 
element. There is a short encoding of 
segmented addresses that appears in instruc- 
tions and reguires only 16 bits. 

It is important to realize that even though 
the Z8001 can operate in nonsegmented mode 
(Chapter 4), it always generates segmented 
addresses. The segment number is supplied by 
the program counter segment number. 
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Figure 3-3. Segmented and Non-Segmented 
Address Formats 
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3.4 Memory 3.4.3 Segmentation and Memory Manage- 
Address ment. Addresses manipulated by the pro- 

Spaces grammer, used by instructions, and output by 

(Continued) the Z8001 are called "logical addresses." An 
external memory-management circuit can 
translate logical addresses into physical 
(actual) memory addresses and perform certain 
checks to insure data and programs are prop- 
erly accessed. 

The Z8010 Memory Management Unit (MMU) 
performs this function for the segmented 
addresses produced by the Z8001 CPU. A 
single MMU keeps a descriptor for each of 64 
segments. This descriptor tells where in 
physical memory the segment lies, how long 
the segment is, and what kind of accesses can 
be made to the segment. The MMU uses these 
descriptors to translate logical segment 
numbers and offsets into 24-bit physical 
addresses (as shown in Figure 3.4). At the 
same time, the MMU checks for errors such as 
writing into a read-only segment or a system 
segment being accessed by a nonsystem pro- 
gram. MMUs are designed to be combined so 
that more than 64 segments can be supported 
at once. The CPU does not reguire MMUs; the 
segment number can be used directly as part 
of a physical address. 

Some of the benefits of the memory manage- 
ment features provided by the MMU are: 

■ Provision for flexible and efficient allocation 
of physical memory resources during the 
execution of programs. 



■ Hardware stack overflow protection. 

■ Support for multiple, independently execut- 
ing programs that can share access to com- 
mon code and data. 

■ Protection from unauthorized or uninten- 
tional access to data or programs. 

■ Detection of obviously incorrect use of 
memory by an executing program. 

■ Separation of users from system functions. 

Segmentation in the Z8001 helps support 
memory management in two ways: 

■ By allowing part of an address (the segment 
number) to be output by the CPU early in a 
memory cycle. This keeps access to the seg- 
ment descriptor in the MMU from adding to 
the basic access time of the memory. 

■ By providing a standard, variable-sized unit 
of memory for the protection, sharing, and 
movement of data. 

In addition, segmentation is the natural 
model for the support of modular programs 
and data in a multi-programming environment. 
It efficiently supports re-entrant programs by 
providing data relocation for different tasks 
using common code. 

More information about the MMU and 
memory management can be found in An 
Introduction to the Z8010 MMU Memory 
Management Unit and in the Z8010 MMU 
Technical Manual. 
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Figure 3-4. Segmented Address Translation 
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Chapter 4 
CPU Operation 



4.1 Intro- This chapter gives a fundamental description 

duction of the operating states of the Z8000 CPU and 

the process of instruction execution. The 
details of instruction execution are described 
in Chapters 5 and 6. Other detailed aspects of 



Z8000 operation are given in Chapter 7 
(Exceptions) and Chapter 8 (Refresh). Chapter 
9 describes CPU operations as they are mani- 
fest on the external pins of the CPU. 



4.2 Operating The Z8000 CPU has three operating states: 
States Running state, Stop/Refresh state, and Bus- 

Disconnect state. Running state is the usual 
state of the processor: the CPU is executing 
instructions or handling exceptions. Stop/ 
Refresh state is entered when the STOP line is 
asserted or the refresh counter indicates that a 
periodic refresh should be done. In this state, 
memory refresh transactions are generated 
continually (see Chapter 8). Bus-Disconnect 
state is entered when the CPU acknowledges a 
bus request and gives up control of the system 
bus. Figure 4.1 shows the three states and the 
conditions that cause state transitions. 

4.2.1 Running State. While the CPU is in 
Running state, it is either executing instruc- 
tions (as described in Section 4.3) or handling 
exceptions (as described in Chapter 7). The 
CPU is normally in Running state, but will 
leave this state in response to one of three con- 
ditions: 

■ The refresh mechanism indicates that a 
periodic refresh needs to be done, in which 
case the CPU temporarily enters Stop/ 
Refresh state. 




STOP RELEASED, OR 
PERIODIC REFRESH 
COMPLETED 



STOP ASSERTED, OR 
PERIODIC REFRESH 
REQUESTED 



BUSREQ ASSERTED, 
AND ACK NOWLEDGED ON 
BUSACK 



Figure 4-1. Operating States and Transistions 



■ An external stop request pushes the CPU 
into Stopped state. 

■ An external bus request pushes the CPU 
into Bus-Disconnect state. 

4.2.2 Stop/Refresh State. While the CPU is in 
Stop/Refresh state, it generates a continuous 
stream of refresh cycles (as discussed in Chap- 
ter 8) and does not perform any other func- 
tions. This state provides for the generation of 
memory refreshes by the CPU and allows 
external devices to suspend CPU operation. 
This feature can be used to force single-step 
operation of the processor or to synchronize 
the CPU with an Extended Processing Unit (as 
described in Section 4.4). 

The CPU enters Stop/Refresh state when the 
refresh mechanism needs to do a refresh or 
when the stop line is activated. It leaves Stop/ 
Refresh state when neither of these conditions 
holds or when a bus request causes the CPU to 
enter Bus-Disconnect state. 

4.2.3 Bus-Disconnect State. While the CPU is 
in Bus-Disconnect state, it does nothing. It 
enters Bus-Disconnect state from either Run- 
ning state or Stop/Refresh stat e when a bus 
request has been received o n BUSREQ and 
acknowledged on BUSACK as (described in 
Chapter 9). While in this state, it disconnects 
itself from the bus by 3-stating its output. It 
leaves Bus-Disconnect state when the external 
bus request has been released. Note that Bus- 
Disconnect state is highest in priority in that 
the presence of a bus request will force the 
CPU into this state, regardless of any con- 
ditions indicating that a different state should 
be entered. 

4.2.4 E ffect of Reset. Activation of the CPU's 
RESET line puts the CPU in a nonoperational 
state within five clock cycles, regardless of its 
previous state or the states of its other inputs. 
The CPU will remain in this state until RESET 
is deactivated. When this occurs, the program 
enters one of the three operating states 
described ab ove, de pending on the state of 
BUSREQ and STOP inputs. Reset is more fully 
described in Chapters 7 and 9. 
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4.3 Instruction While the CPU is in Running state and exe- 
Execution cuting instructions, it is controlled by the Pro- 

gram Status registers (Figure 4.2). The Pro- 
gram Counter gives the address from which 
instructions are fetched, the flags control 
branching (as described in Chapter 6), and 
the control bits determine the mode in which 
the CPU operates and the interrupts that are 
masked (see Chapter 7). 

Instruction execution consists of the repeated 
application of two steps: 

■ Fetch one or more words comprising a 
single instruction from the program memory 
address space at the address specified by 
the Program Counter (PC). 

■ Perform the operation specified by the 
instruction and update the Program Counter 
and flags in the Program Status registers. 

The operation performed by an instruction 
and the way the flags are updated depends on 
the particular instruction being executed and 
is described in Chapter 6. For most instruc- 
tions, the PC value is updated to point to the 
word immediately following the last word of the 
instruction. The effect of this is that instruc- 
tions are fetched sequentially from memory. 
Exceptions to this are Branch, Call, Interrupt 
Return and Load Program Status, and Return 
instructions, which cause the PC to be set to a 
value generated by the instruction. This causes 
a transfer of control with execution continuing 
at the new address in PC. The exact operation 
of these instructions is described in Chapter 6. 

The Z8000 CPU is able to overlap the fetch- 
ing of one instruction with the operation of the 
previous instruction. This facility, called 
Instruction Look-Ahead, is illustrated in Figure 
4.3. This shows the execution of a series of 
memory-to-register instructions, such as a 



value in memory being added to the value in a 
general-purpose register. Part of each instruc- 
tion is fetched while the previous instruction 
execution is being completed. This mechanism 
provides faster execution speed than the 
typical alternative of fetching each instruction 
only after the prior instruction has completed 
execution. 

After executing an instruction and in some 
cases (explained in Chapters 6 and 7) during 
an instruction's execution, the CPU checks to 
see if there are any traps or interrupts pending 
and not masked. If so, it temporarily suspends 
instruction execution and begins a standard 
exception- handling sequence. This sequence, 
which is described fully in Chapter 7, causes 
the value of the Program Status registers to be 
saved and a new value loaded. Instruction exe- 
cution then continues with a new PC value and 
Flag and Control Word value. The effect is to 
switch the execution of the CPU from one pro- 
gram to another. 

4.3.1 Running-State Modes. While the CPU is 
executing instructions, its mode will be con- 
trolled by three control bitsjii the FCW: the 
System/Normal Mode bit (S/N), the Segmenta- 
tion Mode bit (SEG), and the EPA Mode bit. 

4.3.2 Segmented and Nonsegmented 
Modes. The segmentation mode of the CPU 
(segmented or nonsegmented) determines the 
size and format of addresses that are directly 
manipulated by programs. In segmented mode 
(SEG = 1), programs manipulate 23-bit seg- 
mented addresses; in nonsegmented mode 
(SEG = 0), programs generate 16-bit nonseg- 
mented addresses. There are also the following 
differences in the address portions of instruc- 
tions, which are due to the difference in 
address size: 
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Figure 4-2. Program Status Registers 
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4.3 Instruction ■ Indirect and Base Registers are 32-bit 
Execution registers in segmented mode and 16-bit 

(Continued) registers in nonsegmented mode. 

■ Addresses embedded in instructions are 
always 16-bits in nonsegmented mode. They 
consist of a 7-bit segment number and either 
an 8-bit or 16-bit offset in segmented mode. 

Segmented mode is available only on the 
Z8001 CPU; on the Z8002, the segment bit is 
always forced to zero, indicating nonseg- 
mented mode. Because the Z8001 supports 
segmented and nonsegmented modes, it is 
possible to run programs written for the Z8002 
on the Z8001 without alteration. The reverse is 
not possible. The Z8001 CPU always generates 
segmented addresses, even when operating in 
nonsegmented mode. When a memory access 
is made in nonsegmented mode, the offset of 
the segmented address is the 16-bit address 
generated by the program, and the segment 
number is the value of the segment number 
field of the Program Counter. 

4.3.3 Normal and System Modes. The opera- 
tion mode of the CPU (system mode or normal 
mode) determines which instructions can be 
executed and which Stack Pointer register 
is used. _ 

In system mode (S/N - 1), all instructions 
can be executed. While in normal mode, cer- 
tain privileged instructions that alter sensitive 
parts of the machine state (such as I/O opera- 
tions or changes to control registers) cannot be 
executed. 

The second distinction between system and 
normal mode is access to the system or normal 



Stack Pointer. As shown in Figure 4.4, there 
are two copies of the Stack Pointer registers 
(Register 15 in the Z8002 and Registers 14 and 
15 in the Z8001): one for normal mode and one 
for system mode. When in normal mode, a 
reference to the Stack Pointer register by an 
instruction will access the normal Stack 
Pointer. When in system mode, an access to 
the Stack Pointer register will reference the 
system Stack Pointer, unless the Z8001 is run- 
ning in nonsegmented system mode, in which 
case a reference to R14 will access the normal 
mode R14. This is summarized in Table 4.1. 

In normal mode, the system Stack Pointer is 
not accessible; in system mode the normal 
Stack Pointer is accessed by using a special 
Load Control Register instruction (described in 
Chapter 6). 

The CPU switches modes whenever the Pro- 
gram Status Control bits change. This can 
happen when a privileged load control instruc- 
tion is executed or when an exception (inter- 
rupt, trap, or reset) occurs. There is a special 
instruction (system call) whose sole purpose is 
to generate a trap and thus provide a con- 
trolled transition from normal to system mode. 

The distinction between normal/system mode 
allows the construction of a protected operat- 
ing system. This is a program that runs in 
system mode and controls the system's 
resources, managing the execution of one or 
more application programs which run in nor- 
mal mode. Normal and system modes, along 
with Memory Protection, provide the basis for 
protecting the operating system from malfunc- 
tions of application programs. 
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Figure 4-3. Instruction Look- Ahead 



Register 

Referenced by 

Instruction 


System 


Mode 


Normal Mode 


Segmented 


Nonsegmented 


Segmented 


Nonsegmented 


R14 
R15 
RR14 


System R14 
System R15 
System R14 
System R15 


Normal R14 
System R15 
Normal R14 
System R15 


Normal R14 
Normal HI 5 
Normal R14 
Normal RIS 


Normal R14 
Normal R15 
Normal R14 
Normal R15 



Note: 28002 always runs in nonsegmented mode. 

Table 4.1 Registers Accessed by References to R14 and R15. 
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4.4 Extended The Z8000 CPU supports seven types 
Instructions . of extended instructions, which can be exe- 
cuted cooperatively by the CPU and an exter- 
nal Extended Processing Unit. The execution 
of these instructions is controlled by the EPA 
control bit in the FCW. 

When the EPA bit is zero, it indicates that 
there is no Extended Processing Unit con- 
nected to the CPU and causes the CPU to trap 
(as explained in Chapter 7) when it encounters 
an extended instruction. This allows the opera- 
tion of the extended instruction to be simulated 
by software running on the CPU. 

If the EPA bit is set, it indicates that an 
Extended Processing Unit is connected to the 
CPU in order to process the operation encoded 
in the extended instruction. The CPU will fetch 
the extended instruction and perform any 
address calculation required by that instruc- 



tion. If the instruction specifies the transfer of 
data, the CPU will generate the timing signals 
for this transfer. The CPU will fetch and begin 
executing the next instruction in its instruction 
stream. The Extended Processing Unit is 
expected to monitor the CPU's activity, partici- 
pate in extended instruction data transfers 
initiated by the CPU, and execute the 
extended instruction. While the Extended Pro- 
cessing Unit is executing the instruction, the 
CPU can be fetching and executing further 
instructions. If the CPU fetches another 
extended instruction before the Extended Pro- 
cessing Unit is finishe d executing a previous 
instruction, the STOP line may be used to 
delay the CPU until the previous instruction is 
complete. This process is described more fully 
in Chapters 6 and 9. 
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Figure 4-4. General-Purpose Registers 
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Chapter 5 
Addressing Nodes 



5.1 Intro- This chapter describes the eight addressing 

duction modes used by instructions to access data in 

memory or CPU registers. Separate sets of 
examples for the nonsegmented and segmented 
modes of operation are given at the end of the 
chapter. 

An instruction is a consecutive Hst of one or 
more words aUgned at even-numbered byte 
addresses in memory. Most instructions have 
operands in addition to an operation code 



(opcode). These operands may reside in CPU 
registers or memory locations. The modes by 
which references are made to operands are 
called "addressing modes." Figure 5.1 illus- 
trates these modes. Not all instructions can use 
all addressing modes; some instructions can 
use only a few, and some instructions use none 
at all. In Figure 5.1, the term "operand" refers 
to the data to be operated upon. 



Addressing Mode 


Operand Addressing 




Operand Value 


In the Instruction In a Register 


In Memory 




R 




H 










Register 


REGISTER ADDRESS 


OPERAND 1 


register 


IM 










Immediate 


OPERAND 1 


In the instruction 








>IR 












The content of the location 


Indirect 




.„„.„. L_ 






Register 












register 


DA 








The content of the location 


Direct 


Ar.nnr-c' T 






1 








Address 






X 
















REGISTER ADDRESS 







tion whose address is the 


Index 




t 


BASE ADDRESS 


.<Ti 


*^ OPERAND 1 


address in the instruction 




' \y 


plus the content of the 
working register. 








RA 










The content of the location 
whose address is the 




PC VALUE 


Relative 






^ 


content of the program 


DISPLACEMENT 




r rtDCDAun 1 


counter, offset by the 


Address 


■ 


'KJ 










instruction 


'RA 








1 








REGISTER ADDRESS 


— >-| BASE ADDRESS 


whose address is the 


Base 


t 


Address 


DISPLACEMENT 


^rr\ 


»-] OPERAND 1 


address in the register. 


'kJ 


offset by the displacement 
in the instruction 








*BX 
















REGISTER ADDRESS 


— *■ 


BASE ADDRESS 






Base 


-A- 




Index 


REGISTER ADDRESS 


INDEX 


1^ OPERAND 1 


the address in a register 
plus the index value in 
another register. 













*Do not use RO or RRO as indirect, index, or base registers. 

Figure 5-1. Addressing Modes 
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5.2 Use of The 16 general-purpose CPU registers can, 

CPU Registers with the exceptions noted below, be used in 
any of the following ways: 

■ As accumulators, where the data to be 
manipulated resides within the register. 

■ As pointers, where the value in the register 
is the memory address of the operand, 
rather than the operand itself. In string and 
stack instructions, the pointers may be auto- 
matically stepped either forward or back- 
ward through memory locations. 

■ As index or base registers, where the con- 
tents of the register and the word(s) follow- 
ing the instruction are combined to produce 
the address of the operand. This allows effi- 
cient access to a variety of data structures. 

There are two exceptions to the above uses 
of general-purpose registers: 

■ Register RO (or the double register RRO in 
segmented mode) cannot be used as an 
indirect register, base register, index regis- 
ter, or software stack pointer. 

■ Register R15' (or the double register RR 14' 
in the Z8001) is used in acknowledging 
interrupts and therefore can never be used 
as an accumulator in system-mode opera- 
tion. The system-mode registers, R14' and 
R15', are automatically accessed when R14, 
R15, or RR14 are referenced by instructions 
executed in system mode. 

In addition to the general-purpose use of 
Z8000 registers, the following registers are 
used for special purposes: 

■ Register R15 (or the double register RR14 in 
the Z8001) is used as a stack pointer for 
subroutine calls and returns. 

■ The byte register RHl is used in the 
translate buUeted item instructions (TRDB, 
TRDRB, TRIE, TRIRB) and the translate and 
test instructions (TRTDB, TRTDRB, TRTIB, 
TRTIRB). 

■ Register RO is used in extended instructions. 

In Relative Address (RA) mode, the Program 
Counter (PC) is used instead of a general- 
purpose CPU register to supply the base 



address for an effective address calculation. 
The Program Counter normally is used only to 
keep track of the next instruction to be exe- 
cuted; whenever an instruction is fetched from 
memory, the PC is incremented to point to the 
next instruction. For addressing purposes, 
however, the updated PC serves as a base for 
referencing an operand relative to the location 
of an instruction. Operands specified by rela- 
tive addressing reside in the program address 
space if the memory system distinguishes 
between program and data or stack address 
spaces. 

Two of the addressing modes. Direct 
Address and Index, involve an I/O or memory 
address as part of the instruction. I/O 
addresses are always 16 bits long, as are non- 
segmented memory addresses (Z8002), so these 
addresses occupy one word in the instruction. 
Segmented addresses generated by the Z800I 
are 23 bits long. Within an instruction, a seg- 
mented address may occupy either two words 
(16-bit long offset) or one word (8-bit short 
offset). 

As Figure 5.2 illustrates, bit 7 of the seg- 
ment number byte distinguishes the two for- 
mats. When this bit is set, the long-offset 
representation is implied. When the bit is 
cleared, the short-offset address representation 
is implied. For a short-offset address, the 
23-bit segmented address is reduced to 16 bits 
by omitting the eight most significant bits of 
the offset, which are assumed to be zero. 



1 1 1 segment number \jyit:L:::^dy.i.±u\ 


15 




0. 


1 long offset 1 


15 


8 7 





l"l 


segment number 1 

-1 1 1 \ 1 1 l_. 


short offset 1 

r 1 J 1 J 1 1 



Figure 5-2. Segmented Memory Address 
Within Instruction. 

NOTE: Shaded area is reserved. 



5.3 Addressing The following pages contain descriptions of 
Mode the addressing modes of the Z8000. Each 

Descriptions description: 

■ Explains how the operand address is 
calculated, 

■ Indicates which address space (Register, 
I/O, Special I/O, Data Memory, Stack 
Memory, or Program Memory) the operand 
is located in, 

■ Shows the assembly language format used to 
specify the addressing mode, and 

■ Works through an example. 



The descriptions are grouped into two sec- 
tions — one for nonsegmented CPUs, the other 
for segmented CPUs. Users of the Z8002 need 
refer to the first section only; users of the 
Z8001 in nonsegmented mode should also refer 
to the first section, while users of Z8001 in 
segmented mode should refer to the second 
section. In the examples, hexadecimal notation 
is used for memory addresses and the contents 
of registers and memory locations. The % 
symbol precedes hexadecimal numbers in 
assembly language text. 
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5.4 Descrip- In this section, the addressing modes of both 

tions and the Z8002 and the nonsegmented mode Z8001 

Examples are described. 

(Z8002 and 5.4.1 Register (R). In the Register addressing 
Z8001 Nonseg- mode the instruction processes data taken 
mented Mode) from a specified general-purpose register. 
Storing data in a register allows shorter 
instructions and faster execution than occur 
with instructions that access memory. 



After Execution 



INSTRUCTION 



OPERATION REGISTER 



M 



THE OPERAND VALUE IS THE CONTENTS OF THE REGISTER. 

The operand is always in the register 
address space. The register length (byte, 
word, register pair, or register quadruple) is 
specified by the instruction opcode. 

Assembler language format: 

RHn, RLn Byte register 

Rn Word register 

RRn Double-word register 

RQn Quadruple-word register 

Example of R mode: 

LD R2, R3 lload the contents of! 

!R3 into R2! 

Before Execution 



R2 
R3 



A6B8 



9A20 



After Execution 



R2 


9A20 


R3 


9A20 



5.4.2 Immediate (IM). The Immediate address- 
ing mode is the only mode that does not indi- 
cate a register or memory address as the 
source operand. The data processed by the 
instruction is in the instruction. 



INSTRUCTION 



THE OPERAND VALUE IS IN THE INSTRUCTION. 

Because an immediate operand is part of the 
instruction, it is always located in the program 
memory address space. Immediate mode is 
often used to initialize registers. The Z8000 is 
optimized for this function, providing several 
short immediate instructions to reduce the 
length of programs. 

Assembler language format (see also 
Chapter 6): 

#data 

Example of IM mode: 

LDBRH2#%55 lload hex 55 into RH2! 

Before Execution 



R2 5589 



5.4.3 Indirect Register (IR). In the Indirect 
Register addressing mode, the data processed 
is not the value in the specified register. 
Instead, the register holds the address of 
the data. 



INSTRUCTION 



OPERATION REGISTER 
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A single word register is used to hold the 
address. Any general-purpose word register 
can be used except RO. 

Depending on the instruction, the operand 
specified by IR mode will be located in either 
I/O address space (I/O instructions), Special 
I/O address space (Special I/O instructions), 
or data or stack memory address spaces. For 
non-I/O references, the operand will be in 
stack memory space if the stack pointer (R15) 
is used as the indirect register; otherwise, the 
operand will be in data memory space. 

The Indirect Register mode may save space 
and reduce execution time when consecutive 
locations are referenced. This mode can also 
be used to simulate more complex addressing 
modes, since addresses can be computed 
before the data is accessed. 

Assembler language format (see also 
Chapter 6): 

@Rn 

Example of IR mode: 

LD R2 , @R5 ! load R2 with the ! 

Idata addressed by the! 
! contents of R5! 

Before Execution Memory 



R2 


030F 




170A 
170C 
170E 


• 


R3 


0005 


A023 


R4 


2000 


OBOE 


R5 


170C 


lODO 


After 


Execu 


tion 


*• 


R2 


OBOE 






R3 


0005 




R4 


2000 




R5 


170C 





R2 6789 
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5.4 Descrip- 
tions and 
Examples 
(Z8002and 
Z8001 Nonseg- 
mented Mode) 
(Continued) 



5.4.4 Direct Address (DA). In the Direct 
Addressing mode, the data processed is found 
at the address specified in the instruction. 



DATA MEMORY 



M 



Depending upon the instruction, the oper- 
and specified by DA mode will be either in I/O 
space (I/O instructions), in Special I/O space 
(Special I/O instructions), or in data 
memory space. 

This mode is also used by Jump and Call 
instructions to specify the address of the next 
instruction to be executed. (Actually, the 
address serves as an immediate value that is 
loaded into the Program Counter.) 

Assembler language format (see also 
Chapter 6): 

address either memory, I/O, or 

Special I/O 

Example of DA mode: 



LDB RH2,%5E23 



Before Execution 



!load RH2 with the! 
!data in address! 
!5E23! 

Memory 



R2 6789 



5E22 
5E24 



0106 



0304 



After Execution 
R2 



0689 



5.4.5 Index (X). In the Index Addressing 
mode, the instruction processes data located at 
an indexed address in memory. The indexed 
address is computed by adding the address 
specified in the instruction to an "index" con- 
tained in a word register, also specified by the 
instruction. Indexed addressing allows random 
access to tables or other complex data struc- 
tures where the address of the base of the table 
is known, but the particular element index 
must be computed by the program. 



INSTRUCTION 




REGISTER 




OPERATION 1 REGISTER 


-1 


INDEX 


H 


ADDRESS 








' 



DATA MEMORY 
^^ »-| OPERAND I 



Any word register can be used as the index 
register except RO. 

Operands specified by X mode are always in 
the data memory address space except when 
Index Addressing is used with the lump and 
Call instructions. In these cases, the destina- 
tion, computed by adding the index register 
contents to the base address, is in program 
memory space. 



Assembler language format (see also 
Chapter 6): 

address (Rn) 

Example of X mode: 



LD R4,%231A(R3) 



Before Execution 



Head into R4 the con- 
! tents of the memory! 
llocation whose! 
! address is 231 A -I- ! 
!the value in R3! 

Memory 



R3 


OlFE 




2516 

2518 

251A 


I 


R4 


203A 


F3C2 








3D0E 




7ADA 


Address Calculation 

231A 

+ 01FE 

2518 

After Execution 




R3 


OlFE 






R4 


3D0E 





5.4.6 Relative Address (RA). In the Relative 
Addressing mode, the data processed is found 
at an address relative to the current instruc- 
tion. The instruction specifies a two's comple- 
ment displacement which is added to the Pro- 
gram Counter to form the target address. The 
Program Counter setting used is the address of 
the first instruction following the currently exe- 
cuting instruction. (The assembler will take 
this into account in calculating the constant 
that is assembled into the instruction.) 



INSTRUCTION 



K[ 



DISPLACEMENT 
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THE OPERAND VALUE IS THE CONTENTS OF THE LOCATION WHOSE 
ADDRESS IS THE CONTENTS OF PC OFFSET BY THE DISPLACEMENT IN THE 
INSTRUCTION. 

An operand specified by RA mode is always 
in the program memory address space. 

As with the Direct Addressing mode, the 
Relative Addressing mode is used by certain 
program control instructions to specify the 
address of the next instruction to be executed 
(specifically, the result of the addition of the 
Program Counter value and the displacement 
is loaded into the Program Counter, except 
when executing the DJNZ or CALR instruc- 
tions . The displacement is then subtracted from 
the PC, not added to it.) Relative addressing 
allows references forward or backward from 
the current Program Counter value and is 
used only for such instructions as Jumps or 
Calls and special loads (LDR) that can cross 
the normally strict boundary between program 
and data memory. 
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5.4 Descrip- 
tions and 
Examples 
(Z8002 and 
Z8001 Nonseg- 



Assembler languoge format (see also 
Chapter 6): 

address 

Example of RA mode: (Note that the symbol 
mented Mode) "^" '^ ^sed for the value of the current pro- 
(Continued) ^""^"^ counter.) 

LDR R2,$ + %6 !load into R2 the con-! 

! tents of the memory! 
! location whose! 
! address is the current! 
! program counter! 
! + hex 6! 

Because the program counter will be advanced 
to point to the next instruction when the 
address calculation is performed, the constant 
that occurs in the instruction will actually 
be +2. 



Befor 


e Exec 


ution 


Program Memory 


R2 


AOFO 




0202 
0204 
0206 
0208 


: 




PC 


0202 


3102 


/Instruction 








0002 




E801 






FFFE 




Address Calculation 

0206 

+ 2 

0208 

After Execution 






R2 


FFFE 






PC 


0206 





5.4.7 Base Address (BA). The Base Address- 
ing mode is similar to Index mode in that a 
base and offset are combined to produce the 
effective address. In Base Addressing, how- 
ever, a register contains the base address, and 
the displacement is expressed as a 16-bit value 
in the instruction. The two are added and the 
resulting address points to the data to be pro- 
cessed. This addressing mode may be used 
only with the Load instructions. Base 
Addressing mode, as a complement to Index 



mode, allows random access to tables or other 
data structures where the displacement of an 
element within the structure is known, but the 
base of the particular structure must be com- 
puted by the program. 

Any word register can be used ior the base 
address except BO. 

An operand specified by BA mode will be in 
stack memory space if the base register is the 
stack pointer (R15) and in data memory space 
otherwise. 



INSTRUCTION 



OPERATION REGISTER 



DISPLACEMENT 



:2v 



DATA MEMORY 



Assembler language format (see also 
Chapter 6): 

Rn (#disp) 

Example of BA mode: 

LDL R5(#%18),RR2 ! load the long word! 
!inRR2 into the! 
! memory location! 
! whose address is the! 
lvalue in R5 + hex! 
!18! 



OAOO 



Before Execution 

RR2 R2 

R3 

R4 

R5 



1500 



3100 



20AA 



Memory 



Address Calculation 

20AA 

+ 18 

20C2 

After Execution Memoi 


RR2 R2 


OAOO 




R3 


1500 


20C0 


R4 


3100 


20C2 


R5 


20AA 


20C4 






20C6 



20C0 
20C2 
20C4 
20C6 



OABE 



F50D 



BADE 



BODl 



OABE 



OAOO 



1500 



BODl 
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5.4 Descrip- 5.4.8 Base Index (BX). The Base Index 
tions and addressing mode is an extension of the Base 

Examples Addressing mode and may be used only with 

(Z8002 and the Load instructions. In this case, both the 
Z8001 Nonseg- base address and index (displacement) are 
mented Mode) held in registers. This mode allows access to 
(Continued) memory locations whose physical addresses 

are computed at runtime and are not fully 

known at assembly time. 

Any word register can be used for either the 

base address or the index except RO. 

An operand specified by BX mode will be in 

stack memory space if the base register is the 

stack pointer (R15) and in data memory 

otherwise. 

Assembler language format (see also 
Chapter 6): 

Rn (Km) 

Example of BX mode: 

LD R2,R5(R3) ! load into R2 the! 

lvalue whose address! 

lis the value in! 

!R5 + the value in R3! 



Before Execution 



Data Memory 



R2 


1F3A 


R3 


FFFE 


R4 


0300 


R5 


1502 





: 


14FE 


0101 


1500 


BODE 


1502 


F732 




• 



Address Calculation 

1502 

+ FFFE 

1500 

Alter Execution 



R2 


B015 


R3 


FFFE 


R4 


0300 


R5 


1502 



INSTRUCTION 



OPERATION REGISTER 1 REGISTER 2 



HE 



DISPLACEMENT 



— * D 



DATA MEMORY 



THE OPERAND VALUE IS THE CONTENTS OF THE LOCATION WHOSE 
ADDRESS IS THE CONTENTS OF THE ONE REGISTER OFFSET BY THE 
DISPLACEMENT IN THE SECOND REGISTER. 



5.5 Descrip- In this section, «nn» will often be used 

tions and to refer to segment number nn. 

Examples 5.5.1 Register (R). In the Register addressing 

(Segmented mode, the instruction processes data taken 
Z8001) from a specified general-purpose register. Stor- 

ing data in a register allows shorter instruc- 
tions and faster execution than occurs with 
instructions that access memory. 



INSTRUCTION 



OPERATION REGISTER 



K 



THE OPERAND VALUE IS THE CONTENTS OF THE REGISTER. 

The operand is always in the register 
address space. The register length (byte, 
word, register pair, or register quadruple) 
specified by the instruction opcode. 

Assembler language formats (see 
also Chapter 8): 



RHn, RLn 




Byte register 


Rn 




Word register 


RRn 




Double-word register 


RQn 




Quadruple- word 
register 


Example 


of R mode 


: 


LDL RR2,RR4 


!load the contents! 






!of RR4 into RR2! 



Before Execution 



RR2 


R2 
R3 
R4 
R5 

'ixech 
R2 
R3 
R4 
R5 


A6B8 




9A20 


RR4 


38A6 




745E 


After 1 


tion 


RR2 


38A6 




745E 


RR4 


38A6 




745E 



5.5.2 Immediate (IM): The Immediate address- 
ing mode is the only mode that does not indi- 
cate a register or memory address as the loca- 
tion of the source operand. The data processed 
by the instruction is in the instruction. 



THE OPERAND VALUE IS IN THE INSTRUCTION. 
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5.5 Descrip- Because an immediate operand is part of the 

tions and instruction, it is always located in the program 

Examples memory address space. Immediate mode is 

(Segmented often used to initialize registers. The Z8000 is 

Z8001) optimized for this function, providing several 

(Continued) short immediate instructions to reduce the 
length of programs. 

Assembler language format (see also 
Chapter 6): 

#data 

Example of IM mode: 

LDB RH2,#o/o55 ! load hex 55 into RH2! 

Before Execution 



Example of memory access using IR mode: 



R2 6789 



After Execution 



R2 5589 



5.5.3 Indirect Register (IR). In the Indirect 
Register addressing mode, the data processed 
is not the value in the specified register. 
Instead, the register holds the address of 
the data. 



INSTRUCTION 



OPERATION REGISTER 
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Depending upon the instruction, the oper- 
and specified by IR mode will be located in 
either I/O address space (I/O instructions). 
Special I/O address space (Special I/O 
instructions), or data or stack memory address 
spaces. For non-I/O references, the operand 
will be in stack memory space if the stack 
pointer (RR14) is used as the indirect register, 
otherwise the operand will be in data memory 
space. 

A 16-bit register is used to hold an I/O or 
Special I/O address; a register pair is used to 
hold a memory address. Any general-purpose 
register or register pair may be used except RO 
or RRO. 

The Indirect Register mode may save space 
and reduce execution time when consecutive 
locations are referenced. This mode can also 
be used to simulate more complex addressing 
modes, since addresses can be computed 
before the data is accessed. 

Assembler language formats (see also 
Chapter 6): 

@Rn Contains I/O or 

Special I/O address. 

®RRn Contains memory 

address. 



LD R2,@RR4 



Before Execution 



!load intoR2 the! 
lvalue in the memory! 
! location addressed! 
!by the contents of! 
!RR4! 

Memory 



RR2 


R2 
R3 
R4 
R5 

ExecL 

R2 
R3 
R4 
R5 


030F 




0005 


RR4 


2000 




I70C 


After 1 


tion 


RR2 


OBOE 




0005 


RR4 


2000 




I70C 





', 


170A* 


A023 


170C 


OBOE 


170E 


10D3 




• 



Segment Number 20 



Example of I/O using IR mode: 

OUTB@Rl,RL0 
Before Execution 



RO 


0A23 


RI 


0011 



Execution sends the 
data "23" to the I/O 
device addressed by 
"001 1." 



5.5.4 Direct Address (DA). In the Direct 
Addressing mode, the data processed is found 
at the address specified as an operand in the 
instruction. 

INSTRUCTION 



kJ OPERAND I 



Depending upon the instruction, the oper- 
and specified by the Direct Address (DA) 
mode will be either in I/O space (standard I/O 
instructions), or in data memory space. I/O 
and Special I/O addresses are one word long; 
memory addresses can be either one or two 
words long, depending on whether the long or 
short format is used. 

This mode is also used by Jump and Call 
instructions to specify the address of the next 
instruction to be executed. (Actually, the 
address serves as an immediate value that is 
loaded into the Program Counter.) 



26-0001-0924 26-0001-0925 
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5.5 Descrip- 
tions and 
Examples 
(Segmented 
Z8001) 
(Continued) 



Assembler language format (see also 
Chapter 6): 



address 



either memory, I/O, or 
Special I/O where dou- 
ble angle brackets 
" « " and " » " 
enclose the segment 
number, and vertical 
lines "I" and "|" 
enclose short- form 
memory addresses. 



Exomple of DA mode: 

LDB RH2, |« 15» %23|!load RH2 with the! 
lvalue in memory! 
! segment 15, dis-! 
! placement 23 (hex)! 



Before Execution 
R2 



6789 



After Execution 



R2 0689 



Memory 

«15» 0022 
0024 



0206 



0304 



5.5.5 Index (X). In the Index addressing 
mode, the instruction processes data are 
located at an indexed address in memory. The 
indexed address is computed by adding the 
address specified in the instruction to an 
"index" contained in a word register, also 
specified by the instruction. 

The offset of the operand address is com- 
puted by adding the 16-bit index value to the 
8 or 16-bit offset portion pf the address in the 



INSTRUCTION 



OPERATION REGISTER 



h: 



instruction. The segment number of the oper- 
and address comes directly from the instruc- 
tion. (Any overflow is ignored — it neither sets 
the Overflow flag nor increments the segment 
number.) Indexed addressing allows random 
access to table or other complex data struc- 
tures where the address of the base of the table 
is known, but the particular element index 
must be computed by the program. 



^ 



Any word register can be used as the index 
register except RO. The address in the instruc- 
tion can be one or two words, depending on 
whether a long or short offset is used in the 
address. 

Operands specified by X mode are always in 
the data memory address space. 

Assembler language format: 

address (Rn) 

Example of X mode: 

LD R4, «5»%231A(R3) !load into R4 the! 

{contents of the! 
! memory location! 
!whose address is! 
! segment 5,! 
! displacement! 
!23IA + the! 
! value in R3! 



Before Execution 



Memory 



R3 


OlFE 


R4 


203A 





: 


«5» 2516 


F3C2 


2518 


3D0E 


251A 


7ADA 







Address Calculation 

«5» o/o231A 
+ OlFE 

«5» %2518 
After Execution 



R3 


OlFE 


R4 


3D0E 



5.5.6 Relative Address (RA). In the Relative 
Addressing mode, the data processed is found 
at an address relative to the current instruc- 
tion. The instruction specifies a two's comple- 
ment displacement which is added to the offset 
of the Program Counter to form the target 
address. The Program Counter setting used is 
the address of the instruction following the 
currently executing instruction. (The assem- 
bler will take this into account in calculating 
the constant that is assembled into the 
instruction.) 



INSTRUCTION 



OPERATION 


^1 1 




DISPLACEMENT 


,( 


•V, 



>j operand! 



THE OPERAND VALUE IS THE CONTENTS OF THE LOCATION WHOSE 
ADDRESS IS THE CONTENTS OF PC OFFSET BY THE DISPLACEMENT IN THE 
INSTRUCTION. 
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26-0001-0926 26-0001-0927 



5.5 Descrip- An operand specified by RA mode is always 

tions and in the program memory address space. Either 

Examples long or short format addresses may be used. 

(Segmented As with the Direct Addressing mode, the 

Z8001) Relative Addressing mode is also used by cer- 

(Continued) tain program control instructions to specify the 
address of the next instruction to be executed 
(specifically, the result of the addition of the 
Program Counter value and the displacement 
is loaded into the Program Counter, except 
when executing the DJNZ or CALR instruc- 
tions; the displacement is then subtracted from 
the PC, not added to it). Relative addressing 
allows short references forward or backward 
from the current Program Counter value and is 
used only for such instructions as Jumps and 
Calls and special loads (LDR). Note that 
because the segment number is unchanged 
relative addresses are located in the same seg- 
ment as the instruction. 

Assembler language format (see also 
Chopter 6): 

address 

Example of RA mode: 

LDR R2,$ + 6 !load into R2 the con-1 

! tents of the memory! 
! location whose! 
! address is the! 
! current program! 
! counter -1-6! 

Because the program counter will be advanced 
to point to the next instruction when the 
address calculation is performed, the constant 
that occurs in the instruction will actually 
be -t-2. 

Before Execution Memory 

R2 |A0F0 

«13» 0202 

0204 
PC I ODOO I 0206 

0208 



0202 



3102 



0002 



E801 



FFFE 



Instruction 



Address Calculation 
« 13 » 0206 



-1- 




2 


« 13 » 0208 
After Execution 


R2 


FFFE 




PC 


ODOO 






0206 





5.5.7 Base Address (BA). The Base 
Addressing mode is similar to Index mode in 
that a base and displacement are combined to 
produce the effective address. In Base 
Addressing, a register pair contains the 23-bit 
segmented base address and the displacement 
is expressed as a 16-bit value in the instruc- 
tion. The displacement is added to the offset of 
the base address, and the resulting address 
points to the data to be processed. (The seg- 
ment number is not changed.) This addressing 
mode may be used only with the Load instruc- 
tions. Base Addressing mode, as a complement 
to Index mode, allows random access to 
records or other data structures where the 
displacement of an element within the struc- 
ture is known, but the base of the particular 
structure must be computed by the program. 



DISPLACEMENT 



Tr MEMORY 

"•"^ *-| OPERAND I 



THE OPERAND VALUE IS THE CONTENTS OF THE LOCATION WHOSE ADDRESS 
IS THE ADDRESS IN THE REGISTER, OFFSET BY THE DISPLACEMENT IN THE 
INSTRUCTION. 

Any double-word register can be used for 
the base address except RRO. The Base 
Address mode allows access to locations 
whose segment numbers are not known at 
assembly time. 

An operand specified by BA mode will be in 
stack memory space if the base register is the 
stack pointer (RR14) and in data memory space 
otherwise. 

If the segment number is known when the 
program is assembled (or loaded, for example, 
if the loader can resolve symbolic segment 
numbers), the Indexed addressing mode may 
be used to simulate the based addressing 
mode. For example, if R2 is known to hold seg- 
ment number 18, then the operand specified 
using the based address RR2 (#93) can also be 
referenced by the indexed address « 18 » 
%93 (R3). The advantage of this simulation is 
that indexing mode is supported for most 
operations, whereas based is restricted to 
LOAD and LOAD ADDRESS. Thus, using 
Indexed addressing is faster and leads to com- 
pact code. 

Assembler language format (see also 
Chapter 6): 

RRn(#disp) Add the immediate 

value to the contents of 
RRn; the result is the 
address of the operand. 
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5.5 Descrip- 
tions and 
Examples 
(Siegmented 
Z8001) 
(Continued) 



Example of BA mode: 

LDL RR4(#% i8),RR2 !load the long word! 
!inRR2 into the! 
! memory location! 
! whose address is! 
!the value of RR4! 
! + hex 18! 



Before Execution 



RR2 R2 


OAOO 


R3 


1500 


RR4 R4 


2500 


R5 


20AA 



Data Memory 



«31» 





J 


20C0 


OABE 


20C2 


F50D 


20C4 


BADE 


20C6 


BGDl 




; 



Address Calculation 

«13»1502 

± FFEE 

«13»1500 

After Execution 

RR2 

RR4 



R2 


OAOO 


R3 


1500 


R4 


2500 


R5 


20AA 



Data Memory 

«31» 20C0 
20C2 
20C4 
20C6 



OABE 



OAOO 



1500 



BODl 



5.5.8 Base Index (BX). The Base Index 
addressing mode is an extension of the Base 
Addressing mode and may be used only with 
the LOAD and LOAD ADDRESS instructions. 
In this case, both the base address and index 
are held in registers. The index value is added 
to the offset of the base address to produce the 



INSTRUCTION 



OPERATION REGISTER 1 REGISTER 2 



K 



offset of the operand address. The segment 
number of the operand address is the same as 
the base address. This mode allows access to 
memory locations whose physical addresses 
are computed at runtime and are not fully 
known at assembly time. 



DISPLACEMENT 






DATA MEMORY 



THE OPERAND VALUE IS THE CONTENTS OF THE LOCATION WHOSE 
ADDRESS IS THE CONTENTS OF THE ONE REGISTER OFFSET BY THE 
DISPLACEMENT IN THE SECOND REGISTER. 



Any register pair can be used for the base 
address except RRO. Any word register except 
RO can be used for the index. Note that the 
Short Offset format for base addresses is ille- 
gal in registers. 

An operand specified by BX mode will be in 
stack memory space if the base register is the 
stack pointer (RR 14) and in data memory 
otherwise. 

Assembler language format (see also 
Chapter 8): 

RRn (Rn) 

Example of BX mode: 

LD R2,RR4 (R3) !load into R2 the value! 

! whose address is the! 
! contents of RR4 +! 
!the contents of R3! 



3535 



Before Execution 

RR2 R2 

R3 
RR4 R4 

R5 



FFFE 



ODOO 



1502 



Data Memory 

«13» 14FE 
1500 
1502 



0101 



BODE 



F732 



Address Calculation 

«13»1502 
+ FFEE 

«13» 1500 

After Execution 



RR2 R2 


BODE 


R3 


FFFE 


RR4 R4 


ODOO 


R5 


1502 



Data Memory 

«13» 14FE 
1500 
1502 



0101 



BODE 



F732 
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Chapter 6 
Instruction Set 



6.1 Intro- This chapter describes the instruction set of 

duction the Z8000. An overview of the instruction set is 

presented first, in which the instructions are 
divided into ten functional groups. The 
instructions in each group are hsted, followed 
by a summary description of the instructions. 
Significant characteristics shared by the 
instructions in the group, such as the available 
addressing modes, flags affected, or inter- 
ruptibility, are described. Unusual instructions 
or features that are not typical of predecessor 
microprocessors are pointed out. 

Following the functional summary of the 
instruction set, flags and condition codes are 



discussed in relation to the instruction set. This 
is followed by a section discussing interrupt- 
ibility of instructions and a description of 
traps. The last part of this chapter consists of a 
detailed description of each Z8000 instruction, 
listed in alphabetical order. This section is 
intended to be used as a reference by Z8000 
programmers. The entry for each instruction 
includes a description of the instruction, 
addressing modes, assembly language mne- 
monics, instruction formats, execution times 
and simple examples illustrating the use of the 
instruction. 



6.2 Functional This section presents an overview of the 
Summary Z8000 instructions. For this purpose, the 

instructions may be divided into ten functional 

groups: 

■ Load and Exchange 

■ Arithmetic 

■ Logical 

■ Program Control 

■ Bit Manipulation 

■ Rotate and Shift 

■ Block Transfer and String Manipulation 

■ Input/Output 

■ CPU Control 

■ Extended Instructions 

6.2.1 Load and Exchange Instructions. 

Instruction Operand(s) Name of Instruction 



CLR 
CLRB 


dst 


Clear 


EX 
EXB 


dst, src 


Exchange 


LD 

LDB 

LDL 


dst, src 


Load 


LDA 


dst, src 


Load Address 


LDAR 


dst, src 


Load Address Relative 


LDK 


dst, src 


Load Constant 


LDM 


dst, src, num 


Load Multiple 


LDR 

LDRB 

LDRL 


dst, src 


Load Relative 


POP 
POPL 


dst, src 


Pop 


PUSH 


dst, src 


Push 



The Load and Exchange group includes a 
variety of instructions that provide for move- 
ment of data between registers, memory, and 
the program itself (i.e., immediate data). These 
instructions are supported with the widest 
range of addressing modes, including the Base 
(BA) and the Base Index (BX) mode which are 
available here only. None of these instructions 
affect any of the CPU flags. 

The Load and Load Relative instructions 
transfer a byte, word, or long word of data 
from the source operand to the destination 
operand. A special one-word instruction, LDK, 
is also included to handle the frequent require- 
ment for loading a small constant (0 to 15) into 
a register. 

These instructions basically provide one of 
the following three functions: 

■ Load a register with data from a register or 
a memory location. 

■ Load a memory location with data from a 
register. 

■ Load a register or a memory location with 
immediate data. 

The memory location is specified using any 
of the addressing modes (IR, DA, X, BA, 
BX, RA). 

The Clear and Clear Byte instructions can 
be used to clear a register or memory location 
to zero. While this is functionally equivalent to 
a Load Immediate where the immediate data is 
zero, this operation occurs frequently enough 
to justify a special instruction that is more 
compact and faster. 
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6.2 Functional The Exchange instructions swap the contents 
Summary of the source and destination operands. 

(Continued) The Load Multiple instruction provides for 

efficient saving and restoring of registers. This 
can significantly lower the overhead of pro- 
cedure calls and context switches such as 
those that occur at interrupts. The instruction 
allows any contiguous group of 1 to 16 regis- 
ters to be transferred to or from a memory 
area, which can be designated using the DA, 
IR or X addressing modes. (RO is considered to 
follow R15, e.g., one may save R9-R15 and 
R0-R3 with a single instruction.) 

Stack operations are supported by the 
PUSH, PUSHL, POP, and POPL instructions. 
Any general-purpose register (or register pair 
in segmented mode) may be used as the stack 
pointer except RO and RRO. The source 
operand for the Push instructions and the 
destination operand for the Pop instructions 
may be a register or a memory location, 
specified by the DA, IR, or X addressing 
modes. Immediate data can also be pushed 
onto a stack one word at a time. Note that byte 
operations are not supported, and the stack 
pointer register must contain an even value 
when a stack instruction is executed. This is 
consistent with the general restriction of using 
even addresses for word and long word 
accesses. 

The Load Address and Load Address Rela- 
tive instructions compute the effective address 
for the DA, X, BA, BX and RA modes and 
return the value in a register. They are use- 
ful for management of complex data structures. 

6.2.2 Arithmetic Instructions 

Instruction Operand(s) Name of Instruction 



ADC 
ADCB 


dst, src 


Add with Carry 


ADD 

ADDB 

ADDL 


dst, src 


Add 


CP 

CPB 

CPL 


dst, src 


Compare 


DAB 


dst 


Decimal Adjust 


DEC 
DECB 


dst, src 


Decrement 


DIV 
DIVL 


dst, src 


Divide 


EXTS 

EXTSB 

EXTSL 


dst 


Extend Sign 


INC 
INCB 


dst, src 


Increment 


MULT 
MULTL 


dst, src 


Multiply 


NEG 
NEGB 


dst 


Negate 


SBC 
SBCB 


dst, src 


Subtract with Carry 


SUB 

SUBB 

SUBL 


dst, src 


Subtract 



The Arithmetic group consists of instructions 
for performing integer arithmetic. The basic 
instructions use standard two's complement 
binary format and operations. Support is also 
provided for implementation of BCD 
arithmetic. 

Most of the instructions in this group per- 
form an operation between a register operand 
and a second operand designated by any of 
the five basic addressing modes, and load the 
result into the register. 

The arithmetic instructions in general alter 
the C, Z, S and P/V flags, which can then be 
tested by subseguent conditional jump instruc- 
tions. The P/V flag is used to indicate arith- 
metic overflow for these instructions and it is 
referred to as the V (overflow) flag. The byte 
version of these instructions generally alters 
the D and H flags as well. 

The basic integer (binary) operations are 
performed on byte, word or long word oper- 
ands, although not all operand sizes are sup- 
ported by all instructions. Multiple precision 
operations can be implemented in software 
using the Add with Carry, (ADC, ADCB), 
Subtract with Carry (SBC, SBCB) and Extend 
Sign (EXTS, EXTSB, EXTSL) instructions. 

BCD operations are not provided directly, 
but can be implemented using a binary addi- 
tion (ADC, ADCB) or subtraction (SUBB, 
SBCB) followed by a decimal adjust instruc- 
tion (DAB). 

The Multiply and Divide instructions perform 
signed two's complement arithmetic on word or 
long word operands. The Multiply instruction 
(MULT) mutliplies two 16-bit operands and 
produces a 32-bit result, which is loaded into 
the destination register pair. Similarly, Mult- 
iply Long (MULTL) multiplies two 32-bit oper- 
ands and produces a 64-bit result, which is 
loaded into the destination register quadruple. 
An overflow condition is never generated by a 
multiply, nor can a true carry be generated. 
The carry flag is used instead to indicate 
, where the product has too many significant bits 
to be contained entirely in the low-order half 
of the destination. 

The Divide instruction (DIV) divides a 32-bit 
number in the destination register pair by a 
16-bit source operand and loads a 16-bit quo- 
tient into the low-order half of the destination 
register. A 16-bit remainder is loaded into the 
high-order half. Divide Long (DIVL) operates 
similarly with a 64-bit destination register 
quadruple and a 32-bit source. The overflow 
flag is set if the quotient is bigger than the 
low-order half of the destination, or if the 
source is zero. 
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6.2 Functional 6.2.3 Logical Instructions. 



Summary 

(Continued) 


Instruction 

AND 
ANDB 


Operand(s) 

dst, src 


Name of Instruction 

And 




COM 
COMB 


dst 


Complement 




OR 
ORB 


dst, src 


Or 




TEST 

TESTE 

TESTL 


dst 


Test 



XOR 
XORB 



dst, src 



Exclusive Or 



The instructions in this group perform logi- 
cal operations on each of the bits of the oper- 
ands. The operands may be bytes or words; 
logical operations on long word are not sup- 
ported (except for TESTL) but are easily imple- 
mented with pairs of instructions. 

The two-operand instructions, And (AND, 
ANDB), Or (OR, ORB) and Exclusive-Or 
(XOR, XORB) perform the appropriate logical 
operations on corresponding bits of the desti- 
nation register and the source operand, which 
can be designated by any of four basic add- 
ressing modes (R, IR, DA, IM, X). The result is 
loaded into the destination register. 

Complement (COM, COMB) complements 
the bits of the destination operand. Finally, 
Test (TEST, TESTB, TESTL) performs the OR 
operation between the destination operand and 
zero and sets the flags accordingly. The Com- 
plement and Test instructions can use four 
basic addressing modes to specify the 
destination. 

The Logical instructions set the Z and S flags 
based on the result of the operation. The byte 
variants of these instructions also set the Parity 
Flag (P/V) if the parity of the result is even, 
while the word instructions leave this flag 
unchanged. The H and D flags are not affected 
by these instructions. 

6.2.4 Program Control Instructions. 
Instruction Operand(s) Name of Instruction 

CALL dst Call Procedure 

CALR dst Call Procedure Relative 



DJNZ 


r, dst 


Decrement and Jump if 


DBJNZ 




Not Zero 


IRET 




Interrupt Return 


JP 


cc, dst 


Jump 


JR 


cc, dst 


Jump Relative 


RET 


cc 


Return from Procedure 


SO 


src 


System Call 



This group consists of the instructions that 
affect the Program Counter (PC) and thereby 
control program flow. General-purpose 



registers and memory are not altered except 
for the processor stack pointer and the pro- 
cessor stack, which play a significant role in 
procedures and interrupts. (An exception is 
Decrement and Jump if Not Zero (DJNZ), which 
uses a register as a loop counter.) The flags 
are also preserved except for IRET which 
reloads the program status, including the 
flags, from the processor stack. 

The Jump (JP) and Jump Relative (JR) 
instructions provide a conditional transfer of 
control to a new location if the processor flags 
statisfy the condition specified in the condition 
code field of the instruction. (See Section 6.4 
for a description of condition codes.) Jump 
Relative is a one-word instruction that will 
jump to any instruction within the range -254 
to -1-256 bytes from the current location. Most 
conditional jumps in programs are made to 
locations only a few bytes away; the Jump 
Relative instruction exploits this fact to 
improve code compactness and efficiency. 

Call and Call Relative are used for calling 
procedures; the current contents of the PC are 
pushed onto the processor stack, and the effec- 
tive address indicated by the instruction is 
loaded into the PC. The use of a procedure 
address stack in this manner allows straight- 
forward implementation of nested and recur- 
sive procedures. Like Jump Relative, Call 
Relative provides a one-word instruction for 
calling nearby subroutines. However, a much 
larger range, -4092 to +4098 bytes for CALR 
instruction, is provided since subroutine calls 
exhibit less locality than normal control 
transfers. 

Both Jump and Call instructions are 
available with the indirect register, indexed 
and relative address modes in addition to the 
direct address mode. These can be useful for 
implementing complex control structures such 
as dispatch tables. 

The Conditional Return instruction is a com- 
panion to the Call instruction; if the condition 
specified in the instruction is satisfied, it loads 
the PC from the stack and pops the stack. 

A special instruction. Decrement and Jump 
if Not Zero (DJNZ, DBJNZ), implements the 
control part of the basic PASCAL FOR loop in 
a one-word instruction. 

System Call (SC) is used for controlled 
access to facilities provided by the operating 
system. It is implemented identically to a trap 
or interrupt: the current program status is 
pushed onto the system processor stack fol- 
lowed by the instruction itself, and a new pro- 
gram status is loaded from a dedicated part of 
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Set Bit 



Test and Set 



Test condition code 



6.2 Functional the Program Status Area. An 8- bit immediate 
Summary source field in the instruction is ignored by the 

(Continued) CPU hardware. It can be retrieved from the 
stack by the software which handles system 
calls and interpreted as desired, for example 
as an index into a dispatch table to implement 
a call to one of the services provided by the 
operating system. 

Interrupt Return (IRET) is used for returning 
from interrupts and traps, including system 
calls, to the interrupted routines. This is a 
privileged instruction. 

6.2.5 Bit Manipulation Instructions 

Instruction Operand(s) Name of Instruction 

BIT dst, src Bit Test 

BITB 

RES dst, src Reset Bit 

RESB 

SET dst, src 

SETB 

TSET dst 

TSETB 

TCC cc, dst 

TCCB 

The instructions in this group are useful for 
manipulating individual bits in registers or 
memory. In most computers, this has to be 
done using the logical instructions with suit- 
able masks, which is neither natural nor 
efficient. 

The Bit Set (SET, SETB) and Bit Reset (RES, 
RESB) instructions set or clear a single bit in 
the destination byte or word, which can be in 
a register or in a memory location specified by 
any of the five basic addressing modes. The 
particular bit to be manipulated may be speci- 
fied statically by a value (0 to 7 for byte, to 
15 for word) in the instruction itself or it may 
be specified dynamically by the contents of a 
register, which could have been computed by 
previous instructions. In the latter case, the 
destination is restricted to a register. These 
instructions leave the flags unaffected. The 
companion Bit Test instruction (BIT, BITB) 
similarly tests a specified bit and sets the Z flag 
according to the state of the bit. 

The Test and Set instruction (TSET, TSETB) 
is useful in multiprogramming and multipro- 
cessing environments. It can be used for 
implementing synchronization mechanisms 
between processes on the same or differ- 
ent CPUs. 

Another instruction in this group, Test Con- 
dition Code (TCC, TCCB) sets a bit in the des- 
tination register based on the state of the flags 
as specified by the condition code in the 



dst. 


src 


Rotate Left 


dst. 


src 


Rotate Left through 
Carry 


dst, 


src 


Rotate Left Digit 


dst, 


src 


Rotate Right 


dst, 


src 


Rotate Right through 
Carry 


dst. 


src 


Rotate Right Digit 


dst. 


src 


Shift Dynamic Arithmetic 



instruction. (See Section 5.6.1 for a list of con- 
dition codes.) This may be used to control sub- 
sequent operation of the program after the 
flags have been changed by intervening 
instructions. It may also be used by language 
compilers for generating boolean values. 

6.2.6 Rotate and Shift Instructions. 

Instruction Operand(s) Name of Instruction 

RL 
RLE 

RLC 
RLCB 

RLDB 

RR 
RRB 

RRC 
RRCB 

RRDB 

SDA 

SDAB 

SDAL 

SDL 

SDLB 

SDLL 

SLA 

SLAB 

SLAL 

SLL 

SLLB 

SLLL 

SRA 

SRAB 

SRAL 

SRL 

SRLB 

SRLL 

This group contains a rich repertoire of 
instructions for shifting and rotating data 
registers. 

Instructions for shifting arithmetically or 
logically in either direction are available. 
Three operand lengths are supported: 8, 16 
and 32 bits. The amount of the shift, which 
may be any value up to the operand length, 
can be specified statically by a field in the 
instruction or dynamically by the contents of a 
register. The ability to determine the shift 
amount dynamically is a useful feature, which 
is not available in most minicomputers. 

The rotate instructions will rotate the con- 
tents of a byte or word register in either direc- 
tion by one or two bits; the carry bit can be 
included in the rotation. A pair of digit rota- 
tion instructions (RLDB, RRDB) are especially 
useful in manipulating BCD data. 



dst, src 



dst, src 



dst, src 



dst, src 



dst, src 



Shift Dynamic Logical 



Shift Left Arithmetic 



Shift Left Logical 



Shift Right Arithmetic 



Shift Right Logical 
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6.2 Functional 6.2.7 Block Transfer And String Manipula- 
Summary tion Instructions. 



(Continued) i„,„„,,io„ 


Operand(s) 


Name of Instruction 


CPD 


dst, src, r, cc 


Compare and Decrement 


CPDB 






CPDRB 


dst, src, r, cc 


Compare, Decrement and 
Repeat 


CPI 


dst, src, r, cc 


Compare and Increment 


CPIB 






CPIR 


dst, src, r, cc 


Compare, Increment and 


CPIRB 




Repeat 


CPSD 


dst, src, r, cc 


Compare String and 


CPSDB 




Decrement 


CPSDR 


dst, src, r, cc 


Compare String, 


CPSDRB 




Decrement and Repeat 


CPSI 


dst, src, r, cc 


Compare String and 


CPSIB 




Increment 


CPSIR 


dst, src, r, cc 


Compare String, 


CPSIRB 




Increment and Repeat 


LDD 


dst, src, r 


Load and Decrement 


LDDB 






LDDR 


dst, src, r 


Load, Decrement and 


LDRB 




Repeat 


LDI 


dst, src, r 


Load and Increment 


LDIB 






LDIR 


dst, src, r 


Load, Increment and 


LDIRB 




Repeat 


TRDB 


dst, src, r 


Translate and Decrement 


TRDRB 


dst, src, r 


Translate, Decrement and 
Repeat 


TRIB 


dst, src, r 


Translate and Increment 


TRIRB 


dst, src, r 


Translate, Increment and 
Repeat 


TRTDB 


srcl, src2, r 


Translate, Test and 
Decrement 


TRTDRB 


srcl, src2, r 


Translate, Test, 
Decrement and Repeat 


TRTIB 


srcl, src2, r 


Translate, Test and 
Increment 


TRTIRB 


srcl, src2, r 


Translate, Test, Increment 
and Repeat 



This is an exceptionally powerful group of 
instructions that provides a full complement of 
string comparison, string translation and block 
transfer functions. Using these instructions, a 
byte or word block of any length up to 64K 
bytes can be moved in memory; a byte or word 
string can be searched until a given value is 
found; two byte or word strings can be com- 
pared; and a byte string can be translated by 



using the value of each byte as the address of 
its own replacement in a translation table. The 
more complex Translate and Test instructions 
skip over a class of bytes specified by a 
translation table, detecting bytes with values 
of special interest. 

All the operations can proceed through the 
data in either direction. Furthermore, the 
operations may be repeated automatically 
while decrementing a length counter until it is 
zero, or they may operate on one storage unit 
per execution with the length counter decre- 
mented by one and the source and destination 
pointer registers properly adjusted. The latter 
form is useful for implementing more complex 
operations in software by adding other instruc- 
tions within a loop containing the block 
instructions. 

Any word register can be used as a length 
counter in most cases. If the execution of the 
instruction causes this register to be decre- 
mented to zero, the P/V flag is set. The auto- 
repeat forms of these instructions always leave 
this flag set. 

The D and H flags are not affected by any of 
these instructions. The C and S flags are 
preserved by all but the compare instructions. 

These instructions use the Indirect Register 
(IR) addressing mode: the source and destina- 
tion operands are addressed by the contents of 
general-purpose registers (word registers in 
nonsegmented mode and register pairs in seg- 
mented mode). Note that in the segmented 
mode, only the low-order half of the register 
pair gets incremented or decremented as with 
all address arithmetic in the Z8000. 

The repetitive forms of these instructions are 
interruptible. This is essential since the repeti- 
tion count can be as high as 65,536 and the 
instructions can take 9 to 14 cycles for each 
iteration after the first one. The instruction can 
be interrupted after any iteration. The address 
of the instruction itself, rather than the next 
one, is saved on the stack, and the contents of 
the operand pointer registers, as well as the 
repetition counter, are such that the instruc- 
tion can simply be reissued after returning 
from the interrrupt without any visible dif- 
ference in its effect. 
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6.2 Functional 6.2.8 Input/Output Instructions. 
Summary 

(Continued) 



Instruction 

IN 
INB 

IND 
INDB 

INDR 
INDRB 

INI 
INIB 

INIR 
INIRB 

OTDR 
OTDRB 

OTIR 
OTIRB 

OUT 
OUTB 

OUTD 
OUTDB 

OUTI 
OUTIB 

SIN 
SINE 

SIND 
SINDB 

SINDR 
SINDRB 

SINI 
SINIB 

SINIR . 
SINIRB 

SOTDR 
SOTDRB 

SOTIR 
SOTIRB 

SOUT 
SOUTB 

SOUTD 
SOUTDB 

SOUTI 
SOUTIB 



Operand(s) 

dst, src 

dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src 
dst, src, r 
dst, src, r 
dst, src 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src, r 
dst, src 
dst, src, r 
dst, src, r 



Name of Instruction 

Input 

Input and Decrement 

Input, Decrement and 
Repeat 

Input and Increment 

Input, Increment and 
Repeat 

Output, Decrement and 
Repeat 

Output, Increment and 



Output 

Output and Decrement 

Output and Increment 

Special Input 

Special Input and 
Decrement 

Special Input, Decrement 
and Repeat 

Special Input and 
Increment 

Special Input, Increment 
and Repeat 

Special Output, 
Decrement and Repeat 

Special Output, 
Increment and Repeat 

Special Output 

Special Output and 
Decrement 

Special Output and 
Increment 



This group consists of instructions for trans- 
ferring a byte, word or block of data between 
peripheral devices and the CPU registers or 
memory. Two separate I/O address spaces with 
16-bit addresses are recognized, a Standard 
I/O address space and a Special I/O address 
space. The latter is intended for use with 
special Z8000 Family devices, typically the 
Z-MMU. Instructions that operate on the 
Special I/O address space are prefixed with 
the word "special." Standard I/O and Special 
I/O instructions generate different codes on 
the CPU status lines. Normal 8-bit peripherals 
are connected to bus lines AD0-AD7. Standard 
I/O byte instructions use odd addresses only. 
Special 8-bit peripherals such as the MMU, 
which are used with special I/O instructions, 



are connected to bus lines ADg-ADjs. Special 
I/O byte instructions use even addresses only. 

The instructions for transferring a single 
byte or word (IN, INB, OUT, OUTB, SIN, 
SINB, SOUT, SOUTB) can transfer data 
between any general-purpose register and any 
port in either address space. For the Standard 
I/O instructions, the port number may be 
specified statically in the instruction or dynam- 
ically by the contents of the CPU register. For 
the Special I/O instructions the port number is 
specified statically. 

The remaining instructions in this group 
form a powerful and complete complement of 
instructions for transferring blocks of data 
between I/O ports and memory. The operation 
of these instructions is very similar to that of 
the block move instructions described earlier, 
with the exception that one operand is always 
an I/O port which remains unchanged as the 
address of the other operand (a memory loca- 
tion) is incremented or decremented. These 
instructions are also inter ruptible. 

All I/O instructions are privileged, i.e. they 
can only be executed in system mode. The 
single byte/word I/O instructions don't alter 
any flags. The block I/O instructions, includ- 
ing the single iteration variants, alter the Z and 
P/V flags. The latter is set when the repetition 
counter is decremented to zero. 

6.2.9 CPU Control Instructions. 

Instruction Operand(s) Name of Instruction 



COMFLG 

DI 

EI 

HALT 

LDCTL 
LDCTLB 

LDPS 

MBIT 

MREQ 

MRES 

MSET 

NOP 

RESFLG 



flag 

int 

int 

dst, src 



dst 



flag 



Complement Flag 

Disable Interrupt 

Enable Interrupt 

Halt 

Load Control Register 

Load Program Status 
Multi-Micro Bit Test 
Multi-Micro Request 
Multi-Micro Reset 
Multi-Micro Set 
No Operation 
Reset Flag 



SETFLG flag Set Flag 

The instructions in this gi'oup relate to the 
CPU control and status registers (FCW, PSAP, 
REFRESH, etc.), or perform other unusual 
functions that do not fit into any of the other 
groups, such as instructions that support multi- 
microprocessor operation. Most of these 
instructions are privileged, with the exception 
of NOP and the instructions operating on the 
flags (SETFLG, RESFLG, COMFLG, 
LDCTLB). 
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6.2 Functional 6.2.10 Extended Instructions. The Z8000 
Summary architecture includes a powerful mechanism 

(Continued) for extending the basic instruction set through 
the use of external devices known as Extended 
Processing Units (EPUs). (See Section 2.12 for 
a more comprehensive presentation of the 
Extended Processor Architecture.) A group of 
six opcodes, OE, OF, 4E, 4F, 8E and 8F (in 
hexadecimal), is dedicated for the implemen- 
tation of extended instructions using this facil- 
ity. The five basic addressing modes (R, IR, 
DA, IM and X) can be used by extended 
instructions for accessing data for the EPUs. 

There are four types of extended instructions 
in the Z8000 CPU instruction repertoire: EPU 
internal operations; data transfers between 



memory and EPU; data transfers between EPU 
and CPU; and data transfers between EPU flag 
registers and CPU flag and control word. The 
last type is useful when the program must 
branch based on conditions determined by the 
EPU. The action taken by the CPU upon 
encountering extended instructions is depen- 
dent upon the EPA control bit in the CPU's 
FCW. When this bit is set, it indicates that the 
system configuration includes EPUs; therefore, 
the instruction is executed. If this bit is clear, 
the CPU traps (extended instruction trap) so 
that a trap handler in software can emulate the 
desired operation. 



6.3 Processor The processor flags are a part of the pro- 
Flags gram status (Section 2.7.1). They provide a 

link between sequentially executed instructions 
in the sense that the result of executing one 
instruction may alter the flags, and the 
resulting value of the flags may be used to 
determine the operation of a subsequent 
instruction, typically a conditional jump 
instruction. An example is a Test followed by a 
Conditional Jump: 



Isets Z flag if Rl = 0! 
!go to DONE if Z flag is 
set! 



TEST Rl 
JR Z, DONE 



DONE: 

The program branches to DONE if the TEST 
sets the Z flag, i.e., if Rl contains zero. 

The program status has six flags for the use 
of the programmer and the Z8000 processor: 

■ Carry (C) 

■ Zero (Z) 

■ Sign (S) 

■ Parity/Overflow (P/V) 

■ Decimal Adjust (D) 

■ Half Carry (H) 

The flags are. modified by many instructions, 
including the arithmetic and logical 
instructions. 

Appendix C lists the instructions and the 
flags they affect. In addition, there are Z8000 
CPU control instructions which allow the pro- 
grammer to set, reset (clear), or complement 
any or all of the first four flags. The Half-Carry 
and Decimal- Adjust flags are used by the 
Z8000 processor for BCD arithmetic correc- 
tions. They are not used explicitly by the pro- 
grammer. 



The FLAGS register can be separately 
loaded by the Load Control Register (LDCTLB) 
instruction without disturbing the control bits 
in the other byte of the FCW. The contents of 
the flag register may also be saved in a reg- 
ister or memory. 

The Carry (C) flag, when set, generally indi- 
cates a carry out of or a borrow into the high- 
order bit position of a register being used as 
an accumulator. For example, adding the 8-bit 
numbers 225 and 64 causes a carry out of bit 7 
and sets the Carry flag: 





7 


6 


Bit 
5 4 


3 


2 


1 





225 
+ 64 


1 



1 
1 


I 















1 




289 


a 





1 
Carry flag 











1 



The Carry flag plays an important role in the 
implementation of multiple-precision arithmetic 
(see the ADC, SBC instructions). It is also 
involved in the Rotate Left Through Carry 
(RLC) and Rotate Right Through Carry (RRC) 
instructions. One of these instructions is used 
to implement rotation or shifting of long strings 
of bits. 

The Zero (Z) flag is set when the result reg- 
ister's contents are zero following certain 
operations. This is often useful for deter- 
mining when a counter reaches zero. In addi- 
tion, the block compare instructions use the Z 
flag to indicate when the specified comparison 
condition is satisfied. 

The Sign (S) flag is set to one when the most 
significant bit of a result register contains a 
one (a negative number in two's complement 
notation) following certain operations. 
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6.3 Processor The Overflow (V) flag, when set, indicates 
Traps that a two's complement number in a result 

(Continued) register has exceeded the largest number or is 
less than the smallest number that can be 
represented in a two's complement notation. 
This flag is set as the result of an arithmetic 
operation. Consider the following example: 





7 


6 


Bit 
5 4 3 


2 


1 





120 
+ 105 






1 
1 


1 1 
1 0.1 










1 

1 


225 


pi 


1 


1 
Overflow flag 








1 



The result in this case (-95 in two's comple- 
ment notation) is incorrect, thus the overflow 
flag would be set. 

The same bit acts as a Parity (P) flag follow- 
ing logical instructions on byte operands. The 
number of one bits in the register is counted 
and the flag is set if the total is even (that is, 
P = 1). If the total is odd (P = 0), the flag is 
reset. This flag is often referred to as the 
P/V flag. 



The Block Move and String instructions and 
the Block I/O instructions use the P/V flag to 
indicate the repetition counter has decre- 
mented to 0. 

The Decimal- Adjust (D) flag is used for BCD 
arithmetic. Since the algorithm for correcting 
BCD operations is different for addition and 
subtraction, this flag is used to record whether 
an add or subtract instruction was executed so 
that the subseguent Decimal Adjust (DAB) 
instruction can perform its function correctly 
(See the DAB instruction for further discussion 
on the use of this flag). 

The Half-Carry (H) flag indicates a carry out 
of bit 3 or a borrow into bit 3 as the result of 
adding or subtracting bytes containing two 
BCD digits each. This flag is used by the DAB 
instruction to convert the binary result of a 
previous decimal addition or subtraction into 
the correct decimal (BCD) result. 

Neither the Decimal- Adjust nor the Half- 
Carry flag is normally accessed by the pro- 
grammer. 



6.4 Condition The first four flags, C, Z, S, and P/V, are 
Codes used to control the operation of certain "condi- 

tional" instructions such as the Conditional 
Jump. The operation of these instructions is a 
function of whether a specified boolean condi- 
tion on the four flags is satisfied or not. It 
would take 16 bits to specify any of the 65,536 
(216) boolean functions of the four flags. Since 
only a very small fraction of these are general- 
ly of interest, this procedure would be very 
wasteful. Sixteen functions of the flag settings 
found to be frequently useful are encoded in a 
4-bit field called the condition code, which 



forms a part of all conditional instructions. 

The condition codes and the flag settings 
they represent are listed in Section 6.6. 

Although there are sixteen unique condition 
codes, the assembler recognizes more than six- 
teen mnemonics for the conditional codes. 
Some of the flag settings have more than one 
meaning for the programmer, depending on 
the context (PE & OV, Z & EQ, C & ULT, 
etc.). Program clarity is enhanced by having 
separate mnemonics for the same binary value 
of the condition codes in these cases. 



6.5 Instruction Interrupts are discussed in detail in 
Interrupts Section 7. This section looks at the relation- 

and Traps ship between instructions and interrupts. 

When the CPU receives an interrupt 
request, and it is enabled for interrupts of that 
class, the interrupt is normally processed at 
the end of the current instruction. However, 
certain instructions which might take a long 
time to complete are designed to be interrupt- 
ible so as to minimize the length of time it 
takes the CPU to respond to an interrupt. 
These are the iterative versions of the String 
and Block instructions and the Block I/O 
instruction. If an interrupt request is received 
during one of these interruptible instructions, 
the instruction is suspended after the current 
iteration. The address of the instruction itself, 
rather than the address of the following 
instruction, is saved on the stack, so that the 
same instruction is executed again when the 
interrupt handler executes an IRET. The con- 



tents of the repetition counter and the registers 
which index into the block operands are such 
that after each iteration when the instruction is 
reissued upon returning from an interrupt, the 
effect is the same as if the instruction were not 
interrupted. This assumes, of course, the inter- 
rupt handler preserved the registers, which is 
a general requirement on interrupt handlers. 

The longest noninterruptible instruction that 
can be used in normal mode is Divide Long 
(749 cycles in the worst case). Multi-Micro- 
Request, a privileged instruction, can take 
longer depending on the contents of the des- 
tination register. 

Traps are synchronous events that result 
from the execution of an instruction. The 
action of the CPU in response to a trap condi- 
tion is similar to the case of an interrupt (see 
Section 7). Traps are non-maskable. 
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6.5 Instruction 
Interrupts 
and Traps 

(Continued) 



The Z8000 CPUs implement four kinds of 
traps: 

■ Extended Instruction 

■ Privileged Instruction in normal mode 

■ Segmentation violation 

■ System Call 

The Extended Instruction trap occurs when 
an Extended Instruction is encountered, but 
the Extended Processor Architecture Facility is 
disabled, i.e., the EPA bit in the FCW is a 
zero. This allows the same software to be run 
on Z8000 system configurations with or without 
EPUs. On systems without EPUs, the desired 
extended instructions can be emulated by soft- 
ware which is invoked by the Extended 
Instruction trap. 



The privileged instruction trap serves to pro- 
tect the integrity of a system from erroneous or 
unauthorized actions of arbitrary processes. 
Certain instructions, called privileged instruc- 
tions, can only be executed in system mode. 
An attempt to execute one of these instructions 
in normal mode causes a privileged instruction 
trap. All the I/O instructions and most of the 
instructions that operate on the FCW are 
privileged, as are instructions like HALT 
and IRET. 

The System Call instruction always causes a 
trap. It is used to transfer control to system 
mode software in a controlled way, typically to 
request supervisor services. 



6.6 Notation The rest of this chapter consists of detailed 

and Binary descriptions of each instruction, listed in 
Encoding alphabetical order. This section describes the 

notational conventions used in the instruction 
descriptions and the binary encoding for some 
of the common instruction fields (e.g., register 
designation fields). 

The description of an instruction begins with 
the instruction mnemonic and instruction name 
in the top part of the page. Privileged instruc- 
tions are also identified at the top. 

The assembler language syntax is then given 
in a single generic form that covers all the 
variants of the instruction, along with a list of 
applicable addressing modes. 

Example: 



AND dst, src 
ANDB 



dst: R 

src: R, IM, IR, DA, X 



The operation of the instruction is presented 
next, followed by a detailed discussion of the 
instruction. 

The next part specifies the effect of the 
instruction on the processor flags. This is 
followed by a table that presents all the 
variants of the instruction for each applicable 
addressing mode and operand size. For each 
of these variants, the following information is 
provided: 

A. Assembler Language Syntax. The syntax 
is shown for each applicable operand width 
(byte, word or long). The invariant part of the 
syntax is given in UPPER CASE and must 
appear as shown. Lower case characters repre- 
sent the variable part of the syntax, for which 
suitable values are to be substituted. The syn- 
tax shown is for the most basic form of the 



instruction recognized by the assembler. For 
example, 

ADD Rd,#data 

represents a statement of the form 
ADD R3,#35. The assembler will also accept 
variations like ADD TOTAL, #NEW-DELTA 
where TOTAL, NEW and DELTA have been 
suitably defined. 

The following notation is used for register 
operands: 



Rd, Rs, etc.: 


a word register in the 




range R0-R15 


Rbd Rbs: 


a byte register RHn or 




RLn where n = - 7 


RRd RRs: 


a register pair RRO, RR2, 




... RR14 


RQd: 


a register quadruple 




RQO, RQ4, RQ8 or RQ12 



The "s" or "d" represents a source or destina- 
tion operand. Address registers used in 
Indirect, Base and Base Index addressing 
modes represent word registers in nonseg- 
mented mode and register pairs in segmented 
mode. A one- word register used in segmented 
mode is flagged and a footnote explains the 
situation. 

B. Instruction Format. The binary encoding of 
the instruction is given in each case for both 
the nonsegmented and segmented modes. 
Where applicable, both the short and long 
forms of the segmented version are given (SS 
and SL). 

The instruction formats for byte and word 
versions of an instruction are usually com- 
bined. A single bit, labeled "w," distinguishes 
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6.6 Notation them: a one indicates a word instruction, while 
and Binary a zero indicates a byte instruction. 
Encoding Fields specifying register operands are 

(Continued) identified with the same symbols (Rs, RRd, 
etc.) as in Assembler Language Syntax. In 
some cases, only nonzero values are permitted 
for certain registers, such as index registers. 
This is indicated by a notation of the form 
"RS 4^ 0." 

The binary encoding for register fields is as 
follows: 



Register 




Binary 


Rll 


RL3 


1011 


.12 R12 


RL4 


1100 


R13 


RL5 


1101 


,14 R14 


RL6 


1110 


R15 


RL7 


nil 



Register 



RQO 



RQ4 



RRO 



RR2 



RR4 



RR6 



RR8 



RRIO 



RO 
Rl 
R2 
R3 
R4 
R5 
R6 
R7 
R8 
R9 
RIO 



RHO 
RHl 
RH2 
RH3 
RH4 
RH5 
RH6 
RH7 
RLO 
RLl 
RL2 



Binary 

0000 
0001 
0010 
0011 
0100 
0101 
Olio 
01.11 
1000 
1001 
1010 



RQ12 



For easy cross-references, the same symbols 
are used in the Assembler Language Syntax 
and the instruction format. In the case of ad- 
dresses, the instruction format in segmented 
mode uses "segment" and "offset" to corres- 
pond to "address," while the instruction format 
contains "displacement," indicating that the 
assembler has computed the displacement and 
inserted it as indicated. 

A condition code is indicated by "cc" in 
both the Assembler Language Syntax and the 
instruction formats. The condition codes, the 
flag settings they represent, and the binary 
encoding in the instruction are as follows: 



Code 


Meoning 


Flag Setting 


Binory 


F 


Always false 


- 


0000 




Always true 




1000 


Z 


Zero 


Z = 1 


Olio 


NZ 


Not zero 


Z = 


1110 


C 


Carry 


C = 1 


0111 


NC 


No carry 


C = 


nil 


PL 


Plus 


S = 


1101 


MI 


Minus 


S = 1 


0101 


NE 


Not equal 


Z = 


1110 


EQ 


Equal 


Z = 1 


Olio 


OV 


Overflow 


V = 1 


0100 


NOV 


No overflow 


V = 


1100 


PE 


Parity even 


p = 1 


0100 


PO 


Parity odd 


P = 


1100 


GE 


Greater than 
or equal 


(S XOR V) = 


1001 


LT 


Less than 


(S XOR V) = 1 


0001 


GT 


Greater than 


(Z OR (S XOR V)) = 


1010 


LE 


Less than or 
equal 


(Z OR (S XOR V)) = 1 


0010 


UGE 


Unsigned 
greater than 
or equal 


C = 


nil 


ULT 


Unsigned 
less than 


C = 1 


0111 


UGT 


Unsigned 
greater than 


((C =0) AND(Z = 0)) = 1 


1011 


ULE 


Unsigned less 
than or equal 


(C OR Z) = 1 


0011 



Note that some of the condition codes correspond to identical flag settings: i.e., Z-EQ, NZ-NE, 
NC-UGE, PE-OV, PO-NOV. 



C. Cycles. This line gives the execution time 
of the instructions in CPU cycles. 



D. Example. A short assembly language 
example is given showing the use of the 
instruction. 
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6.7 Z8000 
Instruction 
Descriptions 
and Formats 



ADC 

Add With Carry 



ADC dst, src 
ADCB 



dst: R 
src: R 



Operation: 



dst ■«- dst + src + 



Flags: 



The source operand, along with the setting of the carry flag, is added to the destina- 
tion operand and the sum is stored in the destination. The contents of the source are 
not affected. Two's complement addition is performed. In multiple precision arith- 
metic, this instruction permits the carry from the addition of low-order operands to 
be carried into the addition of high-order operands. 

C: Set if there is a carry from the most significant bit of the result; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if both operands were of the same sign 

and the result is of the opposite sign; cleared otherwise 
D: ADC— unaffected; ADCB— cleared 
H: ADC — unaffected; ADCB — set if there is a carry from the most significant bit of 

the low-order four bits of the result; cleared otherwise 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


ADC Rd, Rs 
ADCB Rbd, Rbs 








5 












10 


11010 


w 


Rs 


Rd 






10 


11010 


w 


Rs 


Rd 




5 



















Example: 



Long addition can be done with the following instruction sequence, assuming RO, Rl 
contain one operand and R2, R3 contain the other operand: 

ADD RI,R3 !add low-order words! 

ADC R0,R2 !add carry and high-order words! 

If RO contains %0000, Rl contains %FFFF, R2 contains %4320 and R3 contains 
%0001, then the above two instructions leave the value %4321 in RO and %0000 
inRl. 
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ADD 

Add 



ADD dst, src 

ADDB 

ADDL 



dst: R 

src: R, IM, IR, DA, X 



Operation: 



dst -«- dst + src 



Flags: 



The source operand is added to the destination operand and the sum is stored in the 
destination. The contents of the source are not affected. Two's complement addition 
is performed. 

C: Set if there is a carry from the most significant bit of the result; cleared otherwise 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Set if arithmetic overflow occurs, that is, if both operands were of the same sign 

and the result is of the opposite sign; cleared otherwise 
D: ADD, ADDL— unaffected; ADDB— cleared 
H: ADD, ADDL — unaffected; ADDB — set if there is a carry from the most significant 

bit of the low-order four bits of the result; cleared otherwise 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


ADD Rd, Rs 
ADDB Rbd, Rbs 

ADDL RRd, RRs 
ADD Rd, #data 

ADDB Rbd, #data 

ADDL RRd, #data 

ADD Rd, @Rsl 
ADDB Rbd, @Rsi 

ADDL RRd, @Rsi 








4 
8 

7 
7 

14 

7 
14 












10 


00000 


w 


Rs 


Rd 






10 


00000 


w 


Rs 


Rd 




4 






















10 


010110 


RRs 


RRd 




10 


010110 


RRs 


RRd 




8 


IM: 
















00 


000001 


0000 


Rd 






00 


000001 


0000 


Rd 




7 




data 


data 






















00 


000000 


0000 


Rd 






00 


000000 


0000 


Rd 




7 




data 


data 


data 


data 






















00 


010110 


0000 


RRd 






00 


010110 


0000 


RRd 








31 data (high) ^g 


31 data (high) ig 


14 




15 data (low) q 


15 data (low) q 




















IR: 




00 


00000 


w 


RS:!t0 


Rd 






00 


00000 


w 


Rs*0 


Rd 




7 






















00 


010110 


Rs#0 


RRd 


00 


010110 


Rs*0 


RRd 


14 
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Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


DA: 


ADD Rd, address 
ADDB Rbd, address 

ADDL RRd, address 

ADD Rd, addr(Rs) 
ADDB Rbd, addr(Rs) 

ADDL RRd, addr(Rs) 








9 
15 
10 
16 










01 


00000 


W 


0000 


Rd 




SS 


01 


00000 


W 


0000 


Rd 


10 




address 





segment 


offset 




















SL 


01 


00000 


W 


0000 


Rd 






1 


segment 


00000000 1 


12 




offset 






















01 


010110 


0000 


RRd 




SS 


01 


010110 


0000 


RRd 


16 




address 





segment 


offset 1 




















SL 


01 


010110 


0000 


RRd 






1 1 segment 


00000000 1 


18 




offset 




X: 
















01 


00000 


w 


Rs:;tO 


Rd 




SS 


01 


00000 


w 


Rs?t0 


Rd 


10 




address 





segment 


offset 1 




















SL 


01 


OOOOQ W 


Rs^^O 


Rd 






1 


segment 


00000000 


13 




offset I 






















01 


010110 


Rs#0 


RRd 




SS 


01 


1 0101 10 


Rsito 


RRd 


16 




address 





segment 


offset 




















SL 


01 


010110 


Rs^O 


RRd 1 






1 


segment 


00000000 


19 




offset 

























Example: 



ADD R2, AUGEND laugend A located at %1254! 

Before instruction execution: 



Memory 



R2 



Flags 



1252 




B D 2 l] 


C Z S P/V D H 




6 4 4 


1254 




C z S p d tl 











After instruction execution: 

Memory 
1252 
1254 
1256 



R2 



6 4 4 



C 3 6 5 



Flags 



C Z S P/V D H 



1 d h 



Note 1; Word register in nonsegmented mode, register pair in segmented mode. 



26-0001-0931 
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AND 

And 



AND dst, src 
ANDB 



dst: R 

src: R, IM, IR, DA, X 



Operation: 



dst <- dst AND src 



Flags: 



A logical AND operation is performed between the corresponding bits of the source 
and destination operands, and the result is stored in the destination. A one bit is 
stored wherever the corresponding bits in the two operands are both ones; otherwise 
a zero bit is stored. The source contents are not affected. 

C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

P: AND — unaffected; ANDB — set if parity of the result is even; cleared otherwise 

D: Unaffected 

H: Unaffected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




AND Rd, Rs 
ANDB Rbd, Rs 

AND Rd, #data 
ANDB Rbd, #data 

AND Rd, @Rsl 
ANDB Rbd, @Rsi 

AND Rd, address 
ANDB Rbd, address 

AND Rd, addr(Rs) 
ANDB Rbd, addr(Rs) 








4 

7 
7 
7 
9 

10 








R: 




1 


0001 1 


w 


Rs 


Rd 






10 


0001 1 


« 


Rs 


Rd 1 


4 
















IM: 




00 


0001 1 1 


0000 


Rd 






00 


0001 1 1 


0000 


Rd 1 


7 




data 


data 




















00 0001 10 


0000 


Rd 






00 


1 0001 10 


0000 


Rd 1 






data 


data 


data 


data 1 




IR: 
















00 


00011 


w 


Rs^O 


Rd 






00 


joooi 1 


w 


Rs*0 


Rd 1 


7 
















DA: 




01 


00011 


w 


I Rd 




SB 


01 


0001 1 


w 


0000 


Rd 1 


10 




address 





segment 


offset 




















SL 


01 


0001 1 


w 


0000 


Rd 






1 1 segment 


0000 0000 1 


12 




offset 


















X: 




01 


0001 1 


w 


Rs^O 


Rd 




SS 


01 


0001 1 


w 


Rs:^0 


Rd 


10 




address 





segment 


offset 




















SL 


01 


0001 1 


w 


RS:^0 


Rd 1 






1 


segment 


0000 oooo| 


13 




offset 



























6-14 



Example: ANDB RL3, # %CE 



Before instruction execution 

RL3 



1110 111 







Flags 






c 


z 


S P/V 





H 


c 


z 


s p 


d 


h 



After instruction execution: 

RL3 

I 110 110 I 





Flags 






c 


Z S P/V 


D 


H 


c 


1 1 


d 


h 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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BIT 

Bit Test 



BIT dst, src 
BITB 



dst: R, IR, DA, X 
src: IM 

or 

dst: R 
src: R 



Operation: 



NOT dst (src) 



The specified bit within the destination operand is tested, and the Z flag is set to one 
if the specified bit is zero; otherwise the Z flag is cleared to zero. The contents of the 
destination are not affected. The bit number (the source) can be specified statically 
as an immediate value, or dynamically as a word register whose contents are the bit 
number. In the dynamic case, the destination operand must be a register, and the 
source operand must be RO through R7 for BITB, or RO through R15 for BIT. The bit 
number is a value from to 7 for BITB, or to 15 for BIT, with indicating the least 
significant bit. Note that only the lower four bits of the source operand are used to 
specify the bit number for BIT, while only the lower three bits of the source operand 
are used for BITB. 

Flags: C: Unaffected 

Z: Set if specified bit is zero; cleared otherwise 
S: Unaffected 
V: Unaffected 
D: Unaffected 
H: Unaffected 

Bit Test Static 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




BIT Rd, b 
BITB Rbd, b 

BIT @Rdi , b 
BITB@Rdl, b 

BIT address, b 
BITB address, b 

BIT addr(Rd), b 
BITB addr(Rd), b 








4 
8 

10 
11 






R: 




10 


10011 


W 


Rd 


b 




1 





10011 W 


Rd 


b 


4 














IR: 




00 


10011 


W 


Rd^tO 


b 




( 


)0 


1001 1 W 


Rd^O 


b 


8 
















DA: 




01 


10011 


w 


0000 


b 




88 


01 


10011 V 


V 0000 


b 


11 




address 





segment 


offset 




















8L 


01 


10011 V 


V 0000 


b 






1 segment 


0000 oooo| 


13 




offset 


















X: 




01 


10011 


W 


Rd^^tO 


b 




88 


01 


1 001 1 V 


W Rd:!!:0 


b 


11 




address 





segment 


offset 




















SL 


01 


10011 \ 


IV Rd#0 


b 






1 


segment 


0000 0000 


14 




offset 1 
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Bit Test Static (Continued) 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




BIT Rd, Rs 
BITB Rbd, Rs 








10 










R: 




00 


1001 1 


w 


0000 


Rs 






00 


10011 


w 


0000 


Rs 




10 




0000 


Rd 


0000 


0000 


0000 


Rd 


0000 


0000 





















Example: If register RH2 contains %B2 (101 10010), the instruction 

BITB RH2, #0 
will leave the Z flag set to 1 . 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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CALL 

Call 



CALL dst 



dst: IR, DA, X 



Operation: 



Nonsegmented 
SP ^- SP - 2 
C — SP ^ PC 
PC ^ dst 



Segmented 
SP *- SP - 4 
@SP ^ PC 
PC ^ dst 



Flags: 



The current contents of the program counter (PC) are pushed onto the top of the 
processor stack. The stack pointer used is R15 in nonsegmented mode, or RR14 in 
segmented mode. (The program counter value used is the address of the first instruc- 
tion byte following the CALL instruction.) The specified destination address is then 
loaded into the PC and points to the first instruction of the called procedure. 
At the end of the procedure a RET instruction can be used to return to original pro- 
gram. RET pops the top of the processor stack back into the PC. 

No flags affected 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 
DA: 



CALL @Rdl 
CALL address 



00 


011111 


Rd 


0000 




01 


011111 


0000 


0000 


address 



10 



12 



CALL addr(Rd) 



01 011111 Rd^tO 0000 



address 



13 



1 


00 


011111 


Rd 


oooo| 




ss 


01 


011111 


0000 


0000 





segment 


offset 








01 


011111 


0000 


0000 


SL 


1 segment 


0000 0000 




offset 






SS 


01 


011111 


Rs^O 


0000 





segment 


offset 








01 


011111 


Rs^O 


oooo| 


SL 


1 


segment 


0000 0000 




offset 



15 



18 



20 



18 



21 



Example: In nonsegmented mode, if the contents of the program counter are %1000 and the 

contents of the stack pointer (R15) are %3002, the instruction 

CALL %2520 

causes the stack pointer to be decremented to %3000, the value %1004 (the address 
following the CALL instruction with direct address mode specified) to be loaded into 
the word at location %3000, and the program counter to be loaded with the value 
%2520. The program counter now points to the address of the first instruction in the 
procedure to be executed. 



1: Word register in nonsegmented mode, register pair in segmented mode. 



Note 
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CALR 

Call Relative 



CALRdst 



dst: RA 



Operation: Nonsegmented 

SP ^ SP - 2 
@SP ^ PC 
PC ^ PC - (2 X displacement) 



Segmented 

SP ^ SP - 4 

@SP *- PC 

PC *- PC - (2 X displacement) 



The current contents of the program counter (PC) are pushed onto the top of the 
processor stack. The stack pointer used is R15 if nonsegmented, or RR14 if 
segmented. (The program counter value used is the address of the first instruction 
byte following the CALR instruction.) The destination address is calculated and then 
loaded into the PC and points to the first instruction of a procedure. 

At the end of the procedure a RET instruction can be used to return to the original 
program flow. RET pops the top of the processor stack back into the PC. 

The destination address is calculated by doubling the displacement in the 
instruction, then subtracting this value from the current value of the PC to derive the 
destination address. The displacement is a 12-bit signed value in the range -2048 to 
+2047. Thus, the destination address must be in the range -4092 to +4098 bytes 
from the start of the CALR instruction. In segmented mode, the PC segment number 
is not affected. The assembler automatically calculates the displacement by 
subtracting the PC value of the following instruction from the address given by the 
programmer. 



Flags: 


No flags affected 










Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


RA: 


CALR address 






10 






1101 displacement 


110 1 displacement | 


15 











Example: 



In nonsegmented mode, if the contents of the program counter are %1000 and the 
contents of the stack pointer (R15) are %3002, the instruction 

CALR PROC 

causes the stack pointer to be decremented to %3000, the value %1004 (the address 
following the CALR instruction) to be loaded into the word location %3000, and the 
program counter to be loaded with the address of the first instruction in procedure 
PROC. 
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CLR 

Clear 



CLR dst 
CLRB 



dst: R, IR, DA, X 



Operation: dst ■*- Q 

The destination is cleared to zero. 



Flags: 



No flags affected. 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



R: 

IR: 

DA: 



CLRRd 
CLRB Rbd 

CLR @Rdi 
CLRB @Rdi 

CLR address 
CLRB address 



1 


00110 


w 


Rd * 


1 000 




00 


00110 


w 


Rd * 


1000 




01 


00110 


w 


0000 


1000 


address 



11 



CLRaddr(Rd) 
CLRB addr(Rd) 



01 00110 W Rd:jtO 1000 



address 



12 





10 


00110 


W 


Rd:!^ 


1000 






00 


00110 


W 


Rd^ 


1000 






SB 


01 


001 10 


w 


0000 


loooj 





segment 


offset 








01 


001 1 


w 


0000 


1000 


SL 


1 


segment 


0000 0000 




offset 






SS 


01 


001 10 


w 


RdTiO 


1000 





segment 


offset 








01 


1 T 


w 


Rd#0 


1000 


SL 


1 


segment 


0000 0000 




offset 



12 



14 



12 



15 



Example: If the word at location %ABBA contains 13, the statement 

CLR %ABBA 
will leave the value in the word at location %ABBA. 

Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
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COM 

Complement 



COM dst 
COMB 



dst: R, IR, DA, X 



Operation: (dst -*- NOT dst) 

The contents of the destination are complemented (one's complement); all one bits 
are changed to zero, and vice- versa. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

P: COM — unaffected; COMB — set if parity of the result is even; cleared otherwise 

D: Unaffected 

H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


COMRd 
COMB Rbd 

COM ©Rdi 
COMB feRdi 

COM address 
COMB address 

COM addr(Rd) 
COMB addr(Rd) 








7 
12 

15 
16 










10 


001 10 


W 


Rd ?t 


0000 






10 


001 10 


W 


Rd^O 


ooool 


7 


IR: 
















00 


001 10 


w 


Rd :^ 


0000 






00 


00110 


W 


Rd ^0 


0000 


12 
















DA: 




01 


001 1 


w 


0000 


0000 




SS 


01 


00110 


W 


0000 


0000 


16 




address 





segment 


offset 




















SL 


01 


00110 


W 


0000 


oooo| 






1 


segment 


0000 0000 


18 




offset 




X: 
















01 


00110 


w 


Rd^O 


0000 




SS 


01 


001 10 


W 


Rd:^0 


0000 


16 




address 





segment 


offset 




















SL 


01 


00110 


w 


Rd*0 


0000 






1 


segment 


0000 0000 


19 




offset 



























Example: If register Rl contains o/o2552 (0010010101010010), the statement 

COM Rl 
will leave the value %DAAD (1101101010101101) in Rl. 

Note I: Word register in nonsegmented mode, register pair in segmented mode. 
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COMFLG 

Complement Flag 



COMFLG flag Flag: C, Z, S, P, V 

FLAGS (4:7) o- FLAGS (4:7) XOR instruction (4:7) 



Operation: 



Flags: 



Any combination of the C, Z, S, P or V flags is complemented (each one bit is 
changed to zero, and vice- versa). The flags to be complemented are encoded in a 
field in the instruction. If the bit in the field is one, the corresponding flag is com- 
plemented; if the bit is zero, the flag is left unchanged. Note that the P and V flags 
are represented by the same bit. There may be one, two, three or four operands in 
the assembly language statement, in any order. 

C: Complemented if specified; unaffected otherwise 
Z: Complemented if specified; unaffected otherwise 
S: Complemented if specified; unaffected otherwise 
P/V: Complemented if specified; unaffected otherwise 
D: Unaffected 
H: Undefined 





Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




COMFLG flags 








7 












10001 101 


CZSP/V 


0101 




1 10001101 


CZSP/V 0101 




7 

















Example: 



If the C, Z, and S flags are all clear ( =0), and the P flag is set ( = 1), the statement 

COMFLG P, S, Z, C 
will leave the C, Z, and S flags set ( - 1), and the P flag cleared ( =0). 
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CP 

Compare 



CP dst, src 

CPB 

CPL 



dst: R 

src: R, IM, IR, DA, X 

or 

dst: IR, DA, X 

src: IM 



Operation: 



dst 



Flags: 



The source operand is compared to (subtracted from) the destination operand, and 
the appropriate flags set accordingly, which may then be used for arithmetic and 
logical conditional jumps. Both operands are unaffected, with the only action being 
the setting of the flags. Subtraction is performed by adding the two's complement of 
the source operand to the destination operand. There are two variants of this instruc- 
tion: Compare Register compares the contents of a register against an operand 
specified by any of the five basic addressing modes; Compare Immediate performs a 
comparison between an operand in memory and an immediate value. 

C: Cleared if there is a carry from the most significant bit of the result; set other- 
wise, indicating a "borrow" 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Set if arithmetic overflow occurs, that is, if both operands were of opposite signs 
and the sign of the result is the same as the sign of the source; cleared otherwise 

D: Unaffected 

H: Unaffected 



Compare Register 


Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


CP Rd, Rs 
CPB Rbd, Rbs 

CPL RRd, RRs 
CP Rd, #data 

CPB Rbd, #data 

CPL RRd, #data 

CP Rd, @Rsl 
CPB Rbd, @Rsl 

CPL RRd, @Rsi 








4 
8 

7 
7 

14 

7 
14 












1 


00101 


w 


Rs 


Rd 






10 


00101 


w 


Rs 


Rd 




4 






















10 


01 0000 


Rs 


Rd 






1 


01 0000 


Rs 


Rd 




8 


IM: 


















00 


001011 


0000 


Rd 






00 


001011 


0000 


„- 




7 




data 


data 






















00 


001010 


0000 


Rd 






00 


001010 


0000 


Rd 




7 




data 


data 


data 


data 






















00 


01 0000 


0000 


Rd 






00 


010000 


0000 


„» 








31 data (high) -|6 


31 data (high) ig 


14 




■15 data (low) q 


15 data (low) q 




IR: 


















00 


00101 


w 


Rs9tO 


Rd 






00 


00101 


w 


Rs*0 


Rd 




7 






















00 


01 0000 


Rs?tO 


Rd 






00 


01 0000 


Rs9tO 


Rd 




14 
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Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



DA: 



X: 



CP Rd, address 
CPB Rbd, address 



0100101W0000 Rd 



address 



CPL RRd, address 



01 010000 0000 Rd 



15 



SS 



SL 



SS 



01 


00101 


W 


0000 


Rd 





segment 


offset 



01 00101 


^ 


0000 


Rd 


1 


segment 


0000 ooooj 


offset 1 



01 


01 0000 


0000 


Rd 





segment 


offset 





01 


010000 


0000 


Rd 


SL 


1 


segment 


0000 ooooj 




offset 1 



CP Rd, addr(Rs) 
CPB Rbd, addr(Rbs) 



1 00101 W Rs^tO Rd 



address 



10 



SS 



01 


00101 


W 


Rs*0 


Rd 





segment 


offset 





01 


001 01 


W 


Rs^tO 


Rd 


SL 


1 


segment 


0000 0000 




offset 



CPL RRd, addr(Rs) 



01 010000 Rs^O Rd 



address 



16 



SS 



01 


010000 


Rs*0 


Rd 





segment 


offset 





01 


010000 


Rs*0 


Rd 


SL 


1 


segment 


0000 0000 




offset 1 



10 



12 



16 



18 



10 



13 



16 



19 



Compare Immediate 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



CP@Rdl, #data 



CPB@Rdl, #data 



00 001 10 W Rd:^0 00 01 



data 



00 


00110 


W 


Rd#0 


0001 


data 


data 



11 



11 



0000110WRd:^0 0001 



00 


001 10 


W 


Rd^O 


0001 1 


data 


data 



11 



11 
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Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



DA: 



X: 



CP address, #data 



CPB address, #data 



CP addr(Rd), #data 



CPB addr(Rd), #data 



01 00110 W 0000 0001 



data 



01 


001 10 


W 


0000 


0001 


address 


data 


data 



01 00110W Rd*0 0001 



address 



01 


00110 


W 


Rd=i'0 


0001 


address 


data 


data 



14 



14 



15 



15 



88 



SL 



88 



8L 



88 



8L 



88 



SL 



01 


00110 


W 


0000 


0001 





segment 


offset 


data 



01 


001 10 


W 


0000 


0001 


1 


segment 


0000 0000 


offset 


data 



01 


00110 


W 


0000 


0001 


segment 


offset 


data 


data 



01 


00110 


W 


0000 


0001 


1 


segment 


0000 0000 


offset 


data 


data 



01 


00110 


W 


Rd ^ 


0001 


segment 


offset 1 


data 



01 


00110 


W 


M^ 


0001 


1 


segment 


0000 0000 


offset 


data 



01 


00110 


W 


Rd*0 


0001 





segment 


offset 


data 


data 



01 00110 


vP 


Rd*0 


0001 


1 


segment 


0000 0000 


offset 


data 


data 



15 



17 



15 



17 



15 



18 



15 



18 



Example: If register R5 contains %0400, the byte at location %0400 contains 2, and the source 

operand is the immediate value 3, the statement 

CPB @R5,#3 

will leave the C flag set, indicating a borrow, the S flag set, and the Z and V flags 
cleared. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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CPD 

Compare and Decrement 



CPD dst, src, r, cc 
CPDB 



dst: IR 
src: IR 



Operation: dst - src 

AUTODECREMENT src (by 1 if byte, by 2 if word) 
r -*- r - 1 

This instruction is used to search a string of data for an element meeting the 
specified condition. The contents of the location addressed by the source register are 
compared to (subtracted from) the destination operand, and the Z flag is set if the 
condition code specified by "cc" would be set by the comparison; otherwise the Z 
flag is cleared. See section 6.6.1 for a hst of condition codes. Both operands are 
unaffected. 

The source register is then decremented by one if CPDB, or by two if CPD, thus 
moving the pointer to the previous element in the string. The word register specified 
by "r" (used as a counter) is then decremented by one. 



Flags: 



C: Undefined 

Z: Set if the condition code generated by the comparison matches cc; cleared 

otherwise 
S: Undefined 

V: Set if the result of decrementing r is zero; cleared otherwise 
D: Unaffected 
H: Unaffected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


CPD Rd, @Rsi, r, cc 
CPDB Rbd, @Rsi, r, cc 








20 












1011101 


W 


Rs 9t 


1000 






1011101 


W 


Rs ?t 


1000 




20 




0000 


r 


Rd:ii:0 


cc 


0000 


r 


Rd ^ 


cc 





















Example: 



If register RHO contains %FF, register Rl contains %4001, the byte at location 
%4001 contains %00, and register R3 contains 5, the instruction 

CPDB RHO, @R1, R3, EQ 

will leave the Z flag cleared since the condition code would not have been "egual. 
Register Rl will contain the value %4000 and R3 will contain 4. For segmented 
mode, Rl must be replaced by a register pair. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode 
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CPDR 

Compare Decrement and Repeat 



CPDR dst, src, r, cc 
CPDRB 



dst: IR 
src: IR 



Operation: dst - src 

AUTODECREMENT src (by 1 if byte; by 2 if word) 

r -^ r - 1 

repeat until cc is true or R = 



Flags: 



This instruction is used to search a string of data for an element meeting the 
specified condition. The contents of the location addressed by the source register are 
compared to (subtracted from) the destination operand, and the Z flag is set if the 
condition code specified by "cc" would be set by the comparison; otherwise the Z 
flag is cleared. See section 6.6 for a list of condition codes. Both operands are 
unaffected. 

The source register is then decremented by one if CPDRB, or by two if CPDR, thus 
moving the pointer to the previous element in the string. The word register specified 
"r" (used as a counter) is decremented by one. The entire operation is repeated until 
either the condition is met or the result of decrementing r is zero. This instruction 
can search a string from 1 to 65536 bytes or 32768 words long (the value of r must 
not be greater than 32768 for CPDR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt request 
that is accepted. 

C: Undefined 

Z: Set if the condition code generated by the comparison matches cc; cleared 

otherwise 
S: Undefined 

V: Set if the result of decrementing r is zero; cleared otherwise 
D: Unaffected 
H: Unaffected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 




CPDRRd, @Rsl, r, cc 
CPDRB Rbd, @Rsl,r, cc 








11+9n 










IR: 




1011101 


W 


Rs ^0 


1 1 00 






1011101 


W 


Rs ^0 


1 100 




11 +9n 




0000 


r 


Rd ^ 


cc 


0000 


r 


Rd ?t 


cc 





















Example: 



If the string of words starting at location %2000 contains the values 0, 2, 4, 6 and 8, 
register R2 contains %2008, R3 contains 3, and R8 contains 8, the instruction 

CPDR R3, @R2, R8, GT 

will leave the Z flag set indicating the condition was met. Register R2 will contain the 
value %2002, R3 will still contain 5, and R8 will contain 5. For segmented mode, a 
register pair would be used instead of R2. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements compared. 
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CPI 

Compare and Increment 



CPI dst, src, r, cc 
CPIB 



dst: IR 
src: IR 



Operation: dst - src 

AUTOINCREMENT src (by 1 if byte; by 2 if word) 
r*-r- 1 



Flags: 



This instruction is used to search a string of data for an element meeting the 
specified condition. The contents of the location addressed by the source register are 
compared to (subtracted from) the destination operand and the Z flag is set if the 
condition code is specified by "cc" would be set by the comparison; otherwise the Z 
flag is cleared. See section 6.6.1 for a list of condition codes. Both operands are 
unaffected. 

The source register is then incremented by one if CPIB, or by two if CPI, thus 
moving the pointer to the next element in the string. The source, destination, and 
counter registers must be separate and non- overlapping registers. The word register 
specified by "r" (used as a counter) is then decremented by one. 

C: Undefined 

Z: Set if the condition code generated by the comparison matches cc; cleared 

otherwise 
S: Undefined 

V: Set if the result of decrementing r is zero; cleared otherwise 
D: Unaffected 
H: Unaffected 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



CPI Rd, ®Rsl, r, cc 
CPIBRbd, @Rsl, r, cc 



1011101 


w 


Rs*0 


0000 


0000 


r 


Rd 9t 


cc 



20 



1011101 


W 


Rs^O 


0000 


0000 


r 


Rd#0 


cc 



20 
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Example: This instruction can be used in a "loop" of instructions that searches a string of data 

for an element meeting the specified condition, but an intermediate operation on 
each data element is required. The following sequence of instructions (to be 
executed in non-segmented mode) "scans while numeric," that is, a string is 
searched until either an ASCII character not in the range "0" to "9" (see Appendix 
C) is found, or the end of the string is reached. This involves a range check on each 
character (byte) in the string. For segmented mode, Rl must be changed to a 
register pair. 



LOOP: 



LD 


R3, #STRLEN 


! initialize counter! 


LDA 


Rl, STRSTART 


!load start address! 


LD 


RL0,f9' 


! largest numeric char! 


CPB 


@Rl,fO' 


!test char < '0'! 


JR 


ULT,NONNUMERIC 




CPIB 


RLO, @R1, R3, ULT 


!test char > '0'! 


JR 


Z, NONNUMERIC 




JR 


NOV, LOOP 


! repeat until counter = 0! 



DONE: 



NONNUMERIC: 



! handle non- numeric char! 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
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CPIR 

Compare, Increment and Repeat 



CPIR dst, src, r, cc 
CPIRB 



dst: R 
src: IR 



Operation: dst - src 

AUTOINCREMENT src (by 1 if byte; by 2 if word) 

r "^r - 1 

repeat until cc is true or R = 



Flags: 



This instruction is used to search a string of data for an element meeting the 
specified condition. The contents of the location addressed by the source register are 
compared to (subtracted from) the destination operand, and the Z flag is set if the 
condition code specified by "cc" would be set by the comparison; otherwise the Z 
flag is cleared. See Section 6.6 for a list of condition codes. Both operands are 
unaffected. 

The source register is then incremented by one if CPIRB, or by two if CPIR, thus 
moving the pointer to the next element in the string. The word register specified by 
"r" (used as a counter) is then decremented by one. The entire operation is repeated 
until either the condition is met or the result of decrementing r is zero. This instruc- 
tion can search a string from 1 to 65536 bytes or 32768 words long (the value of r 
must not be greater than 32768 for CPIR). The source, destination, and counter 
registers must be separate and non-overlapping registers. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt request 
that is accepted. 

C: Undefined 

Z: Set if the condition code generated by the comparison matches cc; cleared 

otherwise 
S: Undefined 

V: Set if the result of decrementing r is zero; cleared otherwise 
D: Unaffected 
H: Unaffected 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles^ 



Segmented Mode 



Instruction Format 



Cycles^ 



IR: 



CPIR Rd, @Rsl, r, cc 
CPIRB Rbd,@Rsl, r, cc 



1011101 


w 


RS :^ 


01 00 


0000 


r 


Rd^O 


cc 



11+9n 



1011101 


W 


Rs 5t 


0100 


0000 


r 


Rd ^ 


cc 



11+9n 
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Example: The following sequence of instructions (to be executed in nonsegmented mode) can 

be used to search a string for an ASCII return character. The pointer to the start of 
the string is set, the string length is set, the character (byte) to be searched for is 
set, and then the search is accomplished. Testing the Z flag determines whether the 
character was found. For segmented mode, Rl must be changed to a register pair. 



!hex code for return is D! 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements compared. 



LDA 


Rl, STRSTART 


LD 


R3, #STRLEN 


LDB 


RLO, #% D 


CPIRB 


RLO, @R1, R3, EQ 


JR 


Z, FOUND 
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CPSD 

Compare String and Decrement 



CPSD dst, src, r, cc 
CPSDB 



dst: IR 
src: IR 



Operation: dst - src 

AUTODECREMENT dst and src (by 1 if byte; by 2 if word) 
r -«- r - 1 

This instruction can be used to compare two strings of data until the specified condi- 
tion is true. The contents of the location addressed by the source register are com- 
pared to (subtracted from) the contents of the location addressed by the destination 
register. The Z flag is set if the condition code specified by "cc" would be set by the 
comparison; otherwise the Z flag is cleared. See section 6.6 for a list of condition 
codes. Both operands are unaffected. 

The source and destination registers are then decremented by one if CPSDB, or by 
two if CPSD, thus moving the pointers to the previous elements in the strings. The 
word register specified by "r" (used as a counter) is then decremented by one. 



Flags: 



C: Cleard if there Is a carry from the most significant bit of the result of the com- 
parison; set otherwise, indicating a "borrow". Thus this flag will be set if the 
destination is less than the source when viewed as unsigned integers. 

Z: Set if the condition code generated by the comparison matches cc; cleared 
otherwise 

S: Set is the result of the comparison is negative; cleared otherwise 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




CPSD @Rdl, @Rsi, r, cc 
CPSDB @Rdi,@Rsi,r,cc 








25 










IR: 




1011101 


W 


Rs *t 


1010 






1011101 


w 


Rs# 


1010 




25 




0000 


r 


Rd ^0 


cc 


0000 


' 


Rd# 


cc 



















Example: 



If register R2 contains %2000, the byte at location %2000 contains %FF, register R3 
contains %3000, the byte at location %3000 contains %00, and register R4 contains 
1 , the instruction (executed in nonsegmented mode) 

CPSDB @R2, @R3, R4, UGE 

will leave the Z flag set to 1 since the condition code would have been "unsigned 
greater than or equal" , and the V flag will be set to 1 to indicate that the counter R4 
now contains 0. R2 will contain %1FFF, and R3 will contain %2FFF. For segmented 
mode, R2 and R3 must be changed to register pairs. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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CPSDR 

Compare String, Decrement and Repeat 



CPSDR dst, src,r, cc 
CPSDRB 



dst: IR 
src: IR 



Operation: dst -src 

AUTODECREMENT dst and src (by 1 if byte; by 2 if word) 

r -^ r - 1 

repeat until cc is true or r = 

This instruction is used to compare two strings of data until the specified condition is 
true. The contents of the location addressed by the source register are compared to 
(subtracted from) the contents of the location addressed by the destination register. 
The Z flag is set if the condition code specified by *'cc" would be set by the compar- 
ison; otherwise the Z flag is cleared. See section 6.6 for a list of condition codes. 
Both operands are unaffected. 

The source and destination registers are then decremented by one if CPSDRB, or by 
two if CPSDR, thus moving the pointers to the previous elements in the strings. The 
word register specified by "r" (used as a counter) is then decremented by one. The 
entire operation is repeated until either the condition is met or the result of decre- 
menting r is zero. This instruction can compare strings from 1 to 65536 bytes or from 
1 to 32768 words long (the value of r must not be greater than 32768 for CPSDR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter of the start of this instruction is saved before the interrupt request 
is accepted, so that the instruction can be properly resumed. Seven more cycles 
should be added to this instruction's execution time for each interrupt request that is 
accepted. 



Flags: 



C: Cleared if there is a carry from the most significant bit of the result of the com- 
parison; set otherwise, indicating a "borrow". Thus this flag will be set if the 
destination' is less than the source when viewed as unsigned integers 

Z: Set if the conditon code generated by the comparison matches cc; cleared 
otherwise 

S: Set if the result of the comparison is negative; cleared otherwise 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


CPSDR@Rdl,@Rsi,r,cc 
CPSDRB@Rdi,@Rsl,r,cc 








11-l-14n 












1011101 


W 


Rs 


1110 






1011101 


W 


Rs 


1110 




11 +14n 




0000 


r 


Rd 


cc 


0000 


r 


Rd 


cc 
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Example: If the words from location %1000 to %1006 contain the values 0, 2, 4, and 6, the 

words from location %2000 to %2GG6 contain the values 0, 1, 1, 0, register R13 con- 
tains %1006, register R14 contains %2006, and register RO contains 4, the instruc- 
tion (executed in nonsegmented mode) 

CPSDR @R13, @R14, RO, EQ 

leaves the Z flag set to 1 since the condition code would have been "equal" (loca- 
tions %1000 and %2000 both contain the value 0). The V flag will be set to 1 indi- 
cating r was decremented to 0. R13 will contain %OFFE, R14 will contain %1FFE, 
and RO will contain 0. For segmented mode, R13 and R14 must be changed to 
register pairs. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements compared. 
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CPSI 

Compare String and Increment 



CPSI dst, src, r, cc 
CPSIB 



dst: IR 
src: IR 



Operation: dst - src 

AUTOINCREMENT dst and src (by 1 if byte, by 2 if word) 
r -«- r - 1 



Flags: 



This instruction can be used to compare two strings of data until the specified condi- 
tion is true. The contents of the location addressed by the source register are com- 
pared to (subtracted from) the contents of the location addressed by the destination 
register. The Z flag is set if the condition code specified by "cc" would be set by the 
comparison; otherwise the Z flag is cleared. See Section 6.6.1 for a list of condition 
codes. Both operands are unaffected. 

The source and destination registers are then incremented by one if CPSIB, or by 
two if CPSI, thus moving the pointers to the next elements in the strings. The word 
register specified by "r" (used as a counter) is then decremented by one. 

C: Undefined 

Z: Set if the condition code generated by the comparison matches cc; cleared 

otherwise 
S: Undefined 

V: Set if the result of decrementing r is zero; cleared otherwise 
D: Unaffected 
H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



CPSI @Rdi,@Rsi,r,cc 
CPSIB @Rdl,@Rsl,r,cc 



1011101 


W 


Rs ^ 


0010 


0000 


r 


Rd^O 


cc 



25 



1011101 


W 


H»*Q 


0010 


0000 


r 


Rd^O 


cc 



25 
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Example: 



This instruction can be used in a "loop" of instructions which compares two strings 
until the specified condition is true, but where an intermediate operation on each 
data element is required. The following sequence of instructions, to be executed in 
nonsegmented mode, attempts to match a given source string to the destination 
string which is known to contain all upper-case characters. The match should suc- 
ceed even if the source string contains some lower-case characters. This involves a 
forced conversion of the source string to upper-case (only ASCII alphabetic letters 
are assumed, see Appendix C) by resetting bit 5 of each character (byte) to before 
comparison. 



!load start addresses! 
! initialize counter! 



LOOP: 



DONE: 



LDA 


Rl, SRCSTART 


LDA 


R2, DSTSTART 


LD 


R3, #STRLEN 


RESB 


@R1,#5 


CPSIB 


@R1,@R2, R3, NE 


JR 


Z, NOTEQUAL 


JR 


NOV, LOOP 



! force upper- case! 
! compare until not equal! 
!exit loop if match fails! 
! repeat until counter = 0! 
! match succeeds! 



NOTEQUAL: • !match fails! 

In segmented mode, Rl and R2 must both be register pairs. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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CPSIR 

Compare String, Increment and Repeat 



CPSIR dst,src,r,cc 
CPSIRB 



dst: IR 
src: IR 



Operation: dst - src 

AUTOINCREMENT dst and src (by 1 if byte, by 2 if word) 

r -^ r - 1 

repeat until cc is true or r = 

This instruction is used to compare two strings of data until the specified condition is 
true. The contents of the location addressed by the source register are compared to 
(subtracted from) the contents of the location addressed by the destination register. 
The Z flag is set if the condition code specified by "cc" would be set by the com- 
parison; otherwise the Z flag is cleared. See section 6.6.1 for a list of condition 
codes. Both operands are unaffected. The source and destination registers are then 
incremented by one if CPSIRB, or by two if CPSIR, thus moving the pointers to the 
next elements in the strings. The word register specified by 'V (used as a counter) is 
then decremented by one. The entire operation is repeated until either the condition 
is met or the result of decrementing r is zero. This instruction can compare strings 
from 1 to 65536 bytes or from 1 to 32768 words long (the value of r must not be 
greater than 32768 for CPSIR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven cycles 
should be added to this instruction's execution time for each interrupt request that is 
accepted. The source, destination, and counter registers must be separate and non- 
overlapping registers. 



Flags: 



C: Cleared if there is a carry from the most significant bit of the result of the last 
comparison made; set otherwise, indicating a ''borrow". Thus this flag will be set 
if the last destination element is less than the last source element when viewed as 
unsigned integers. 

Z: Set if the condition code generated by the comparison matches cc; cleared 
otherwise 

S: Set if the result of the last comparison made is negative; cleared otherwise 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 




CPSIR <&Rdi,<S'Rsi,r,cc 
CPSIRB @Rdl,@Rsi,r,cc 








11-H4n 










IR: 




1011101 


W 


Rs ?t 


0110 






1011101 


W 


Rs ^0 


0110 




11 +14n 




0000 


r 


Rd ^ 


cc 


0000 


r 


Rd ?t 


cc 
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Example: The CPSIR instruction can be used to compare test strings for lexicographic order. 

(For most common character encoding — for example, ASCII and EBCDIC — lexi- 
cographic order is the same as alphabetic order for alphabetic test strings that do 
not contain blanks.) 

Let SI and S2 be text strings of lengths LI and L2. According to lexicographic 
ordering, SI is said to be "less than" or "before" S2 if either of the following is true: 

■ At the first character position at which SI and 
S2 contain different characters, the character 
code for the SI character is less than the 
character code for the S2 character. 

■ SI is shorter than S2 and is equal, character for 
character, to an initial substring of S2. 

For example, using the ASCII character code, the following strings are ascending 
lexicographic order: 

A 

AU A 
ABC 
A BCD 
ABD 

Let us assume that the address of SI is in RR2, the address of S2 is in RR4, the 
lengths LI and L2 of SI and S2 are in RO and Rl, and the shorter of LI and L2 is in 
R6. The the following sequence of instructions will determine whether SI is less than 
S2 in lexicographic order: 



CPSIRB @RR2, 9RR4, R6, NE 



JR Z,CHAR_COMPARE 

CP R0,R1 

JR LT, S1_IS„LESS 
JR Sl_NOT_Less 

CHAR_COMPARE: 
JR ULT, S1_IS_LESS 

Sl_NOT LESS: 



IScan to first unequal character! 
!The following flags settings are possible: 
Z = 0, V = 1: Strings are equal through LI 
character (Z = 0, V = cannot occur). 
Z=l,V = Oorl:A character position was 
found at which the strings are unequal. 
C = 1 (S = or 1): The character in the RR2 
string was less (viewed as numbers from to 
255, not as numbers from -128 to + 127). 
C = (S = or 1): The character in the RR2 
string was not less! 

!If Z= 1, compare the characters! 
! Otherwise, compare string lengths! 



lULT is another name for C = 1 ! 



S1_IS_LESS: 
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DAB 

Decimal Adjust 



DAB dst 



dst: R 



Operation: 



dst ^ DA dst 



Flags: 



The destination byte is adjusted to form two 4-bit BCD digits following an addition or 
subtraction operation. For addition (ADDB, ADCB) or subtraction (SUBB, SBCB), 
the following table indicates the operation performed: 





Carry 


Bits 4-7 


HFlag 


Bits 0-3 


Number 


Carry 




Before 


Value 


Before 


Value 


Added 


After 


Instruction 


DAB 


(Hex) 


DAB 


(Hex) 


To Byte 


DAB 







0-9 





0-9 


00 










0-8 





A-F 


06 





ADDB 





0-9 


1 


0-3 


06 





ADCB 





A-F 





0-9 


60 


1 







9-F 





A-F 


66 


1 







A-F 


1 


0-3 


66 


1 




1 


0-2 





0-9 


60 


1 




1 


0-2 





A-F 


66 


1 


SUBB 





0-9 





0-9 


00 





SBCB 





0-8 


1 


6-F 


FA 







1 


7-F 





0-9 


AO 


1 




1 


6-F 


1 


6-F 


9A 


1 



The operation is undefined if the destination byte was not the result of a valid addi- 
tion or subtraction of BCD digits. 



C: Set or cleared according to the table above 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

V: Unaffected 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


DAB Rbd 






5 










10 1 10000 


Rd 


0000 






1 1 10000 


Rd 




5 
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Example: If addition is performed using the BCD values 15 and 27, the result should be 42. 

The sum is incorrect, however, when the binary representations are added in the 
destination location using standard binary arithmetic. 

0001 0101 
+ 0010 0111 



0011 1100 = %3C 
The DAB instruction adjusts this result so that the correct BCD representation is 
obtained. 

0011 1100 
+ 0000 0110 



0100 0010 = 42 
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DEC 

Decrement 



DEC dst, src 
DECB 



dst: R, IR, DA, X 
src: IM 



Operation: 



dst -«- dst - src (where src = 1 to 16) 



Flags: 



The source operand (a value from 1 to 16) is subtracted from the destination operand 
and the result is stored in the destination. Subtraction is performed by adding the 
two's complement of the source operand to the destination operand. The source 
operand may be omitted from the assembly language statement and defaults to the 
value 1. 

The value of the source field in the instruction is one less than the actual value of the 
source operand. Thus, the coding in the instruction for the source ranges from to 
15, which corresponds to the source values 1 to 16. 

C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Set if arithmetic overflow occurs, that is, if the operands were of opposite signs, 

and the sign of the result is the same as the sign of the source; cleared otherwise 
D: Unaffected 
H: Unaffected 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



R: 
IR: 
DA: 



DEC Rd, #n 
DECB Rbd, #n 

DEC @Rdi , #n 
DECB feRdl , #n 

DEC address, #n 
DECB address, #n 



10 


10101 


[^ 


Rd 


n - 1 



00 10101 W Rd:^0 n - 1 



01 10101 W 0000 n - 1 



address 



11 



13 



DEC addr(Rd), #n 
DECB addr(Rd), #n 



01 10101 W Rd^O n - 1 



address 



14 





10 


10101 


W 


Rd 


n - 1 








00 


10101 


W 


Rd^tO 


n - 1 








01 


10101 


w 


0000 


n-, 


ss 





segment 


offset 








01 


10101 


W 


0000 


n - 1 


SL 


1 


segment 


0000 0000 




offset 






SS 


01 


10101 


w 


Rd^itO 


.-, 





segment 


offset 








01 


10101 


w 


Rd^O 


n - 1 


SL 


1 


segment 


0000 ooooj 




offset 



11 



14 



16 



14 



17 



|Example: If register RIO contains %002A, the statement 

DEC RIO 
will leave the value o/o0029 in RIO. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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DI 

Disable Interrupt 



Privileged Instruction 



Dlint 



Int: VI, NVI 



Operation: If instruction (0) = then NVI -«- 

If instruction (1) = then VI ^- 



Any combination of the Vectored Interrupt (VI) or Non- Vectored Interrupt (NVI) 
control bits in the Flags and Control Word (FCW) are cleared to zero if the cor- 
responding bit in the instruction is zero, thus disabling the appropriate type of inter- 
rupt. If the corresponding bit in the instruction is one, the control bit will not be 
affected. All other bits in the FCW are not affected. There may be one or two 
operands in the assembly language statement, in either order. 



Flags: 


No flags affected. 










Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




DI int 






7 








01111100 000000 Y Y 


01111100 000000 y y 


7 











Example: If the NVI and VI control bits are set (1) in the FCW, the instruction: 

DI VI 

will leave the NVI control bit in the FCW set (1) and will leave the VI control bit in 
the FCW cleared (0). 
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DIV 

Divide 



DIV dst, src dst: R 

DIVL src: R, IM, IR, DA, X 

Operation: Word: (dst is register pair, src is word): 

dst (0:31) is divided by src (0:15) 
(dst (0:31) = quotient x src (0:15) + remainder) 
dst (16:31) "*- quotient 
dst (0:15) ■*- remainder 

Long: (dst register quadruple, src is long word or register pair): 
dst (0:63) is divided by src (0:31) 
(dst (0:63) = quotient x src (0:31) + remainder) 
dst (32:63) •*- quotient 
dst (0:31) -*- remainder 

The destination operand (dividend) is divided by the source operand (divisor), the 
quotient is stored in the low-order half of the destination and the remainder is stored 
in the high-order half of the destination. The contents of the source are not affected. 
Both operands are treated as signed, two's complement integers and division is per- 
formed so that the remainder is of the same sign as the dividend. For DIV, the 
destination is a register pair and the source is a word value; for DIVL, the destina- 
tion is a register quadruple and the source is a long word value. 

There a four possible outcomes of the Divide instruction, depending on the division, 
and the resulting quotient: 

CASE 1. If the quotient is within the range -215 to 215 _ i inclusive for DIV or 
-2^1 to 2^1 - I inclusive for DIVL, then the quotient and remainder are left in the 
destination register as defined above, the overflow and carry flags are cleared to 
zero, and the sign and zero flags are set according to the value of the quotient. 

CASE 2. If the divisor is zero, the destination register remains unchanged, the 
overflow and zero flags are set to one and the carry and sign flags are cleared to 
zero. 

CASE 3. If the quotient is outside the range -216 to 216 - 1 inclusive for DIV or -232 
to 232- I inclusive for DIVL, the destination register contains an undefined value, 
the overflow flag is set to one, the carry and zero flags are cleared to zero, and the 
sign flag is undefined. 

CASE 4. If the quotient is inside the range of case 3 but outside the range of case 
1 , then all but the sign bit of the quotient and all of the remainder are left in the 
destination register, the overflow and carry flags are set to one, and the sign and 
zero flags are set according to the value of the quotient. In this case, the sign flag 
can be replicated by subsequent instruction into the high-order half of the destina- 
tion to produce the two's complement representation of the quotient in the same 
precision as the original dividend. 

Flags: C: Set if V is set and the quotient lies in the range from -216 ^^ 2I6 - i inclusive for 

DIV or in the range from -232 to 232 _ i inclusive for DIVL; cleared otherwise 
Z: Set if the quotient or divisor is zero; cleared otherwise 
S: Undefined if V is set and C is clear (overflow); otherwise set if the quotient is 

negative, cleared if the quotient is non-negative. 
V: Set if the divisor is zero or if the computed quotient lies outside the range from 

-2l5 to 2I5 - 1 inclusive for DIV or outside range from -231 to 231 - 1 inclusive 

for DIVL; cleared otherwise 
D: Unaffected 
H: Unaffected 
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Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles2 



Segmented Mode 



Instruction Format 



Cycles^ 



IM: 



IR: 



DA: 



X: 



DIV RRd, Rs 
DIVL RQd, RRs 
DIV RRd, #data 

DIVL RQd, #data 

DIV RRd, @Rsi 
DIVL RQd, @Rsi 

DIV RRd, address 



DIVL RQD, address 



DIV RRd, addr{Rs) 



DIVL RQd, addr(Rs) 



10 


011011 


Rs 


Rd 1 



F' 


011010 


Rs 


Rd 



00 011011 0000 Rd 



data 



01 011011 0000 Rd 



address 



01 011010 0000 Rd 



address 



01 011011 Rs^itO Rd 



address 



01 011010 Rs^O Rd 



address 



00 


011010 


0000 


Rd 


31 


data (high) 


16 


15 


data (low) 






00 


011011 


Rs^O 


Rd 




00 


011010 


Rs:^0 


Rd 



10 


011011 


Rs 


Rd 



1 


011010 


Rs 


Rd 1 



00 011011 0000 Rd 



data 



00 


011010 


0000 


Rd 


31 


data (high) 


16 


15 


data (low) 






00 


011011 


RS:^0 


Rd 



00 


011010 


RS:A0 


Rd 



ss 



SL 



88 



01 


011011 


0000 


Rd 





segment 


offset 



01 


011011 


0000 


Rd 


1 


segment 


0000 0000 


offset 



01 


011010 


0000 


Rd 





segment 


offset 





01 


011010 


0000 


Rd 


8L 


'1 


segment 


0000 0000 




offset 1 



88 



8L 



88 



01 


011011 


Rs?tO 


Rd 





segment 


offset 



01 


011011 


Rs*0 


Rd 


1 segment 


0000 ooooj 


offset 



01 


011010 


Rs^ii^O 


Rd 





segment 


offset 





01 


011010 


Rs*0 


Rd 


SL 


1 


segment 


0000 0000 




offset 



Note 1; Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: Execution times for each instruction are given in the table under Example. 
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Example: The following table gives the DIV instruction execution times for word and long 

word operands in all possible addressing modes. 



src 




Word 




Long Word 






NS 


SS 


SL 


NS 


SS 


SL 


R 


107 


— 


— 


744 


— 


— 


IM 


107 


— 


— 


744 


— 


— 


IR 


107 


107 


107 


744 


744 


744 


DA 


108 


108 


111 


745 


746 


748 


X 


109 


109 


112 


746 


746 


749 


(Divisor is zero) 


R 


13 


13 


13 


30 


30 


30 


IM 


13 


13 


13 


30 


30 


30 


IR 


13 


13 


13 


30 


30 


30 


DA 


14 


15 


17 


31 


32 


34 


X 


15 


15 


18 


32 


32 


35 


(Absolute val 


ue of the high-order half of the 


dividend 


is larger tha 


n the 


absolute value of thi 


s divisor) 










R 


25 


25 


25 


51 


51 


51 


IM 


25 


25 


25 


51 


51 


51 


IR 


25 


25 


25 


51 


51 


51 


DA 


26 


27 


29 


52 


53 


55 


X 


27 


27 


30 


53 


53 


56 



Note that for proper execution, the '*dst field" in the instruction format encoding 
must be even for DIV, and must be a multiple of 4 (0, 4, 8, 12) for DIVL. If the 
source operand in DIVL is a register, the "src field" must be even. 

If register RRO (composed of word register RO and Rl) contains % 00000022 and 
register R3 contains 6, the statement 

DIV RR0,R3 

will leave the value %00040005 in RRO (Rl contains the quotient 5 and RO contains 
the remainder 4). 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 

Note 2: The execution time for the instruction will be lower than indicated for divide by zero and certain 
overflow conditions. 
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DJNZ 

Decrement and Jump if Not Zero 



DJNZ R, dst 
DBINZ 



dst: RA 



Operation: 



R^ R - 1 

If R :^ then PC 



PC - (2 X displacement) 



The register being used as a counter is decremented. If the contents of the register 
are not zero after decrementing, the destination address is calculated and then 
loaded into the program counter (PC). Control will then pass to the instruction 
whose address is pointed to by the PC. When the register counter reaches zero, con- 
trol falls through to the instruction following DJNZ or DBJNZ. This instruction pro- 
vides a simple method of loop control. 

The relative addressing mode is calculated by doubling the displacement in the 
instruction, then subtracting this value from the updated value of the PC to derive 
the destination address. The updated PC value is taken to be the address of the 
instruction byte following the DJNZ or DBJNZ instruction, while the displacement is a 
7-bit positive value in the range to 127. Thus, the destination address must be in 
the range -252 to 2 bytes from the start of the DJNZ or DBJNZ instruction. In the 
segmented mode, the PC segment number is not affected. The assembler automatic- 
ally calculates the displacement by subtracting the PC value of the following instruc- 
tion from the address given by the programmer. Note that DJNZ or DBJNZ cannot be 
used to transfer control in the forward direction, nor to another segment in 
segmented mode operation. 



Flags: 


No flags affected 










Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




DJNZ R, displacement 
DBJNZ Rb, displacement 






11 






RA: 


1111 r W disp 


1111 r W disp 


11 











Example: 



DJNZ and DBJNZ are typically used to control a "loop" of instructions. In this exam- 
ple for nonsegmented mode, 100 bytes are moved from one buffer area to another, 
and the sign bit of each byte is cleared to zero. Register RHO is used as the counter. 

linitalize counter! 
!load start address! 



LOOP: 



LDB 


RH0,#100 


LDA 


Rl, SRCBUF 


LDA 


R2, DSTBUF 


LDB 


RL0,@R1 


RESB 


RL0,#7 


LDB 


@R2, RLO 


INC 


Rl 


INC 


R2 


DBJNZ 


RHO, LOOP 



!load source byte! 
!mask off sign bit! 
! store into destination! 
! advance pointers! 

! repeat until counter = 0! 



NEXT: 



For segmented mode, Rl and R2 must be changed for register pairs. 
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Privileged Instruction 



EI 

Enable Interrupts 



EI int 



Int: VI, NVI 



Operation: If instruction (0) = then NVI m- 1 

If instruction (1) = then VI ^ 1 



Any combination of the Vectored Interrupt (VI) or Non-Vetored Interrupt (NVI) con- 
trol bits in the Flags and Control Word (FCW) are set to one if the corresponding bit 
in the instruction is zero, thus enabling the appropriate type of interrupt. If the cor- 
responding bit in the instruction is one, the control bit will not be affected. All other 
bits in the FCW are not affected. There may be one or two operands in the assembly 
language statement, in either order. 



Flags: 


No flags affected 










Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




EI int 






7 








01111100 000001 Y Y 


01111100 000001 Y y 


7 











Example: 



If the NVI contol bit is set (1) in the FCW, and the VI control bit is clear (0), the 
instruction 

EI VI 

will leave both the NVI and VI control bits in the FCW set (1) 
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EX 

Exchange 



EX dst, src 
EXB 



dst: R 

src: R, IR, DA, X 



Operation: tmp -*- src (tmp is a temporary internal register) 

src <- dst 
dst •*- tmp 

The contents of the source operand are exchanged with the contents of the destina- 
tion operand. 



Flags: 



No flags affected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


EXRd,Rs 
EXB Rbd, Rbs 

EX Rd, @Rsi , 
EXB Rbd, @Rsi 

EX Rd, address 
EXB Rbd, address 

EX Rd, addr(Rs) 
EXB Rbd, addr(Rs) 








6 
12 

15 
16 










10 


10110 


W 


Rs 


Rd 






10 


10110 


W 


Rs 


Rd 


6 


IR: 
















00 


10110 


W 


Rs*0 


Rd 






00 


10110 


W 


Rs^j^O 


Rd 


12 


DA: 
















01 


10110 


w 


0000 


Rd 




88 


01 


10110 


W 


0000 


Rd 


16 




address 





segment 


offset 




















8L 


01 


10110 


W 


0000 


Rd 






1 


segment 


0000 0000 


18 




offset 


















X: 




01 


10110 


w 


Rs^tO 


Rd 




88 


01 


10110 


W 


RS:)tO 


Rd 1 


16 




address 





segment 


offset j 




















SL 


01 


10110 


W 


RSitO 


Rd 






1 


segment 


0000 0000 


19 




offset 



























Example: If register RO contains 8 and register R5 contains 9, the statement 

EX R0,R5 
will leave the values 9 in RO, and 8 in R5. The flags will be left unchanged. 

Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
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EXTSB dst 

EXTS 

EXTSL 



dst: R 



EXTS 

Extend Sign 



Operation: Byte 

if dst (7) = then dst (8:15) ^ 000... 000 
else dst (8:15) ^ 111. ..Ill 

Word 

if dst (15) = then dst (16:31) m- 000... 000 
else dst (16:31) ^ 111. ..Ill 

Long 

if dst (31) = then dst (32:63) *- 000... 000 
else dst (32:63) *- 111. ..Ill 



Flags: 



The sign bit of the low-order half of the destination operand is copied into all bit 
positions of the high-order half of the destination. For EXTS, the destination is a 
register pair; for EXTSL, the destination is a register quadruple. 

This instruction is useful in multiple precision arithmetic or for conversion of small 
signed operands to larger signed operands (as,, for example, before a divide). 

No flags affected 



Example: 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


EXTSB Rd 
EXTS RRD 
EXTSL RQd 








11 
11 
11 












10 


1 10001 


Rd 


0000 




10 


110001 


Rd 


0000 




11 




















10 


1 10001 


Rd 


1010 




1 


1 1 0001 


Rd 


1 010 




11 




















10 


1 10001 


Rd 


011 1 






10 


1 10001 


Rd 


0111 




11 



















If register pair RR2 (composed of word registers R2 and R3) contains % 12345678, 
the statement 

EXTS RR2 

will leave the value %00005678 in RR2 (because the sign bit of R3 was 0). 
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HALT 

Halt 



Privileged Instruction 



Operation: 



Flags: 



The CPU operation is suspended until an interrupt or reset request is received. This 
instruction is used to synchronize the Z8000 with external events, preserving its state 
until an interrupt or reset request is honored. After an interrupt is serviced, the 
instruction follo wing HA LT is executed. While halted, memory refresh cycles will 
still occur, and BUSREQ will be honored. 

No flags affected 





Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles^ 


Instruction Format 


Cycles^ 




HALT 








8 + 3n 












01111010 00000000 






01111010 00000000 1 


8 + 3n 

















Note 1: Interrupts are recognized at the end of each 3-cycle period; thus n = number of periods without 
interruption. 
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Privileged Instruction 



IN 

(SIN) 

(Special) Input 



IN dst, src 
INB 

SIN dst, src 
SINB 



dst: R 

src: IR, DA 

dst: R 
src: DA 



Operation dst -*- src 

The contents of the source operand, an Input or Special Input port, are loaded into 
the destination register. IN and INB are used for normal I/O operation; SIN and 
SINB are used for Special I/O operation. 



Example: 



Flags: 


No flags affected 
































Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


IN Rdi , @Rs 
INBRbdi, @Rs 

IN Rd, port 
INB Rbd, port 

SIN Rd, port 
SINB Rbd, port 








10 
12 












00 


11110 


W 


Rs 


Rd 






00 


11110 


W 


Rs 


Rd 


10 


DA: 
















00 


11101 


W 


Rd 


01 OS 






00 


11101 


w 


Rd 


010S 




12 




port 


port 



















If register R6 contains the I/O port address %0123 and the port %0123 contains 
%FF, the statement 

INB RH2, @R6 

will leave the value %FF in register RH2. 



Note 1. Word register in nonsegmented mode; register pair in segmented mode. 
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INC 

Increment 



INC dst, src 
INCB 



dst: R, IR, DA, X 
src: IM 



Operation: 



dst ^*- dst + src (src = 1 to 16) 



Flags: 



The source operand (a value from 1 to 16) is added to the destination operand and 
the sum is stored in the destination. Two's complement addition is performed. The 
source operand may be omitted from the assembly language statement and defaults 
to the value 1 . 

The value of the source field in the instruction is one less than the actual value of the 
source operand. Thus, the coding in the instruction. for the source ranges from 
to 15, which corresponds to the source values 1 to 16. 

C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Set if arithmetic overflow occurs, that is, if both operands were of the same sign 

and the result is of the opposite sign; cleared otherwise 
D: Unaffected 
H: Unaffected 



Example: 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


INC Rd, #n 
INCB Rbd, #n 

INC@Rdl, #n 
INCB @Rdi , #n 

INC address, #n 
INCB address, #n 

INC addr(Rd), #n 
INCB addr(Rd), #n 








4 
11 

13 
14 










1 


10100 


W 


Rd 


n - 1 






10 


10100 


w 


Rd 


n - 1 


4 


IR: 
















00 


10100 


W 


Rd^'O 


n - 1 






00 


10100 


W 


Rd?tO 


n - 1 


11 


DA: 
















01 


10100 


W 


0000 


n - 1 




88 


01 


10100 


W 


0000 


n - 1 


14 




address 





segment 


offset 






















8Li 


01 


10100 


w 


0000 


n - 1 






1 segment 


0000 oooo| 


16 




offset 




X: 
















01 


10100 


W 


Rd^tO 


n - 1 




88 


01 


1 0100 


w 


Rd*0 


n - 1 


14 




address 





segment 


offset j 






















SL 


01 


10100 


w 


Rd*0 


n - 1 






1 


segment 


0000 0000 


17 




offset 1 


















_ 









If register RH2 contains %21, the statement 

INCB RH2,#6 
will leave the value %27 in RH2. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Privileged Instruction 



IND 
(SIND) 

(Special) Input and Decrement 



IND dst, src, r 
INDB 
SIND 
SINDB 



dst: IR 
src: IR 



Operation: dst -*- src 

AUTODECREMENT dst (by 1 byte, by 2 if word) 
r -*- r - 1 



Flags: 



This instruction is used for block input of strings of data. IND and INDB are used for 
normal I/O operation; SIND and SINDB are used for special I/O operation. The con- 
tents of the I/O port addressed by the source word register are loaded into the 
memory location addressed by the destination register. I/O port addresses are 16 
bits. The destination register is then decremented by one if a byte instruction or by 
two if a word instruction, thus moving the pointer to the previous element of the 
string in memory. The word register specified by "r" (used as a counter) is then 
decremented by one. The address of the I/O port in the source register is 
unchanged. 

C: Unaffected 

Z: Unaffected 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




IND @Rdl, @Rs, r 
INDB @Rdi, @Rs, r 
SIND @Rdl, @Rs, r 
SINDB @Rdi, @Rs, r 








21 










IR: 




0011101 


W 


Rs ^ 


OOOS 






0011101 


W 


Rs^O 


OOOS 




21 




0000 


r 


Rd ^0 


1000 


0000 


r 


Rd:)t 


1000 





















Example: 



In segmented mode, if register RR4 contains % 02004000 (segment 2, offset %4000), 
register R6 contains the I/O port address %0228, the port %0228 contains %05B9, 
and register RO contains %0016, the instruction 

IND @RR4, @R6, RO 

will leave the value %05B9 in location %02004000, the value %02003FFE in RR4, 
and the value %0015 in RO. The V flag will be cleared. Register R6 still contains the 
value %0228. In nonsegmented mode, a word register would be used instead of 
RR4. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Privileged Instruction 



INDR 
(SINDR) 

(Special) Input, Decrement and Repeat 





INDR dst, src, r dst: IR 




INDRB src: IR 




SINDR 




SINDRB 


Operation: 


dst -«- src 




AUTODECREMENT dst (by 1 if byte, by 2 if word) 




r ^ r - 1 




repeat until r = 



Flags: 



This instruction is used for block input of strings of data. INDR and INDRB are used 
for normal I/O operation; SINDR and SINDRB are used for special I/O operation. 
The contents of the I/O port addressed by the source word register are loaded into 
the memory location addressed by the destination register. I/O port addresses are 16 
bits. The destination register is then decremented by one if a byte instruction, or by 
two if a word instruction, thus moving the pointer to the previous element of the 
string in memory. The word register specified by "r" (used as a counter) is then 
decremented by one. The address of the I/O port in the source register is 
unchanged. The entire operation is repeated until the result of decrementing r is 
zero. This instruction can input from 1 to 65536 bytes or 32768 words (the value for r 
must not be greater than 32768 for INDR or SINDR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt request 
that is accepted. 

C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
fl: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


CyclesZ 


IR: 


INDR @Rdl, @Rs, r 
INDRB @Rdl , @Rs, r 
SINDR ®Rdi, @Rs, r 
SINDRB @Rdi, @Rs, r 








11+10n 












0011 101 


W 


RS :!i:0 


100S 






0011101 


W 


Rs ^0 


100S 




11 +10n 




000 


r 


Rd# 


0000 


0000 


r 


Rd # 


0000 
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Example: If register Rl contains %202A, register R2 contains the Special I/O address %OAFC, 

and register R3 contains 8, the instruction 

SINDRB @R1, @R2, R3 

will input 8 bytes from the special I/O port OAFC and leave them in descending 
order from %202A to %2023. Register Rl will contain %2022, and R3 will contain 0. 
R2 will not be affected. The V flag will be set. This example assumes nonsegmented 
mode; in segmented mode, Rl would be replaced by a register pair. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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INI 
(SINI) 

(Special) Input and Increment 



Privileged Instruction 



INI dst, src, r 

INIB 

SINI 

SINIB 



dst: IR 
src: IR 



Operation: dst <4- src 

AUTOINCREMENT dst (by 1 if byte, by 2 if word) 
r -*- r - 1 



Flags: 



This instruction is used for block input of strings of data. INI, INIB are used for nor- 
mal I/O operation; SINI, SINIB are used for special I/O operation. The contents of 
the I/O port addressed by the source word register are loaded into the memory loca- 
tion addressed by the destination register. I/O port addresses are 16 bits. The 
destination register is then incremented by one if a byte instruction, or by two if a 
word instruction, thus moving the pointer to the next element of the string in 
memory. The word register specified by "r" (used as a counter) is then decremented 
by one. The address of the I/O port in the source register is unchanged. 

C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


INI @Rdi, @Rs, r 
INIB@Rdl, @Rs, r 
SINI@Rdl, @Rs, r 
SINIB @Rdl, @Rs, r 








21 












0011101 


w 


Rs^O 


100S 






001 1 101 


W 


Rs # 


100S 




21 




0000 


r 


Rd^O 


1000 


0000 


r 


Rd#0 


1000 





















Example: 



In nonsegmented mode, if register R4 contains %4000, register R6 contains the I/O 
port address °/o0229, the port %0229 contains %B9, and register RO contains %0016, 
the instruction 

INIB @R4, @R6, RO 

will leave the value %B9 in location %4000, the value %4001 in R4, and the value 
%0015 in RO. Register R6 still contains the value %0229. The V flag is cleared. In 
segmented mode, R4 would be replaced by a register pair. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Privileged Instruction _ 1 JN lit 

(SINIR) 

(Special) Input, Increment and Repeat 



INIR dst, src, r 
INIRB 
SINIR 
SINIRB 



dst: IR 
src: IR 



Operation: dst t- src 

AUTOINCREMENT dst (by 1 if byte, by 2 if word) 
r ■«- r — 1 
repeat until r = 

This instruction is used for block input of strings of data. INIR and INIRB are used 
for normal I/O operation; SINIR and SINIRB are used for special I/O operation. The 
contents of the I/O port addressed by the source word register are loaded into the 
memory location addressed by the destination register. I/O port addresses are 16 
bits. The destination register is then incremented by one if a byte instruction, or by 
two if a word instruction, thus moving the pointer to the next element in the string. 
The word register specified by "r" (used as a counter) is then decremented by one. 
The address of the I/O port in the source register is unchanged. The entire operation 
is repeated until the result of decrementing r is zero. This instruction can input from 
1 to 65536 bytes or 32768 words (the value for r must not be greater than 32768 for 
INIR or SINIR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt request 
that is accepted. 



Flags: 



C: Unaffected 
Z: Unaffected 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


INIR @Rdl, @Rs, r 
INIRB @Rdl, @Rs, r 
SINIR @Rdl, @Rs, r 
SINIRB @Rdl, @Rs, r 








11 + 10n 












0011101 


W 


Rs 7t 


OOOS 






0011101 


W 


Rs :^0 


OOOS 




11+10n 




0000 


r 


Rd :;t:0 


0000 


0000 


r 


Rd #0 


0000 
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Example: In nonsegmented mode, if register Rl contains %2023, register R2 contains the I/O 

port address %0551, and register R3 contains 8, the statement 

INIRB @R1,@R2, R3 

will input 8 bytes from port %0051 and leave them in ascending order from %2023 
to %202A. Register Rl will contain %202B, and R3 will contain 0. R2 will not be 
affected. The V flag will be set. In segmented mode, a register pair must be used 
instead of Rl. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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Privileged Instruction 



IRET 

Interrupt Return 



IRET 



Operation: Nonsegmented 

SP ^ SP + 2 (Pop "identifier") 
PS ^ @SP 
SP <^ SP + 4 



Segmented 

SP -^ SP + 2 (Pop "identifier") 

PS ^ @SP 

SP ^ SP + 6 



Flags: 



This instruction is used to return to a previously executed procedure at the end of a 
procedure entered by an interrupt or trap (including a System Call instruction). 
First, the "identifier" word associated with the interrupt or trap is popped from the 
system processor stack and discarded. Then contents of the location addressed by 
the system processor stack pointer are popped into the program status (PS), loading 
the Flags and Control Word (FCW) and the program counter (PC). The new value 
of the FCW is not effective until the next instruction, so that the status pins will not 
be affected by the new control bits until after the IRET instruction execution is com- 
pleted. The next instruction executed is that addressed by the new contents of th6 
PC. The system stack pointer (R15 if nonsegmented, or RR14 if segmented) is used to 
access memory. When using a Z8001, the operation of IRET in nonsegmented mode 
is undefined. A Z8001 must be in segmented mode when an IRET instruction is 
performed. 

C: Loaded from processor stack 
Z: Loaded from processor stack 
S: Loaded from processor stack 
P/V: Loaded from processor stack 
D: Loaded from processor stack 
H: Loaded from processor stack 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




IRET 








13 














01111011 


00000000 






01111011 


00000000 




16 



















Example: 



In the nonsegmented Z8002 version, if the program counter contains %2550, the 
system stack pointer (RI5) contains %3000, and locations %3000, %3002 and %3004 
contain °/o7F03, a saved FCW value, and %1004, respectively, the instruction 

IRET 

will leave the value °/o3006 in the system stack pointer and the program counter will 
contain %1004, the address of the next instruction to be executed. The program 
status will be determined by the saved FCW value. 
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JP 

lump 



IP cc, dst 



dst: IR, DA, X 



Operation: 



If cc is satisfied, then PC -*- dst 



Flags: 



A conditional jump transfers program control to the destination address if the condi- 
tion specified by "cc" is satisfied by the flags in the FCW. See section 6.6 for a list 
of condition codes. If the condition is satisfied, the program counter (PC) is loaded 
with the designated address; otherwise, the instruction following the JP instruction is 
executed. 

No flags affected 



Example: 



Destination 

Addressing 

Mode 


Assembler Longuage 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 


IR: 


JP cc, @Rdi 
JP cc, address 

JP cc, addr(Rd) 








10/7 
7/7 

8/8 










00 


011110 


Rd:)!:0 


cc 






00 


011110 


Rd:^0 


cc 


15/7 


DA: 
















01 


011110 


0000 


cc 




SB 


01 


011110 


0000 


cc 


8/8 




address 





segment 


offset 




















SL 


01 


011110 


0000 


cc 






1 


segment 


0000 0000 


10/10 




offset 




X: 
















01 


011110 


Rd^tO 


cc 




SS 


01 


011110 


Rd^O 


" 


11/11 




address 





segment 


offset 1 




















SL 


01 


011110 


Rd#0 


00 






1 


segment 


0000 0000 


11/11 




offset 

























If the carry flag is set, the statement 

JP C, %1520 

replaces the contents of the program counter with %1520, thus transferring control 
to that location. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: The two values correspond to jump taken and jump not taken. 
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JR 

Jump Relative 



JR cc, dst 



dst: RA 



Operation: if cc is satisfied then PC -*- PC + (2 x displacement) 

A conditional jump transfers program control to the destination address if the condi- 
tion specified by "cc" is satisfied by the flags in the FCW. See section 6.6.1 for a list 
of condition codes. If the condition is satisfied, the program counter (PC) is loaded 
with the designated address; otherwise, the instruction following the JR instruction is 
executed. The destination address is calculated by doubling the displacement in the 
instruction, then adding this value to the updated value of the PC to derive the 
destination address. The updated PC value is taken to be the address of the instruc- 
tion byte following the JR instruction, while the displacement is an 8-bit signed value 
in the range -128 to +127. Thus, the destination address must be in the range -254 
to +256 bytes from the start of the JR instruction. In the segmented mode, the PC 
segment number is not affected. 

The assembler automatically calculates the displacement by subtracting the PC value 
of the following instruction from the address given by the programmer. 



Flags; 



No flags affected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


RA: 


JR cc, address 




6 






1110 cc displacement 


1110 CO displacement 


6 











Example: 



If the result of the last arithmetic operation executed is negative, the following four 
instructions (which occupy a total of twelve bytes) are to be skipped. This can be 
accomplished with the instruction 

JR MI, $ + 14 
If the S flag is not set, execution continues with the instruction following the JR. 
A byte- saving form of a jump to the label LAB is 

JR LAB 

where LAB must be within the allowed range. The condition code is "blank" in this 
case, and indicates that the jump is always taken. 
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LD 

Load 



LD dst, src 

LDB 

LDL 



dst: R 

src: R, IR, DA, X, BA, BX 



dst: IR, DA, X, BA, BX 

src: R 

or 

dst: R, IR, DA, X 

src: IM 



Operation: 



dst -«- src 



Flags: 



The contents of the source are loaded into the destination. The contents of the source 
are not affected. 

There are three versions of the Load instruction: Load into a register, load into 
memory and load an immediate value. 

No flags affected 



Load Register 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


LD Rd, Rs 
LDB Rbd, Rbs 

LDL RRd, RRs 

LD Rd, @Rsi 
LDB Rbd, @Rsi 

LDL RRd, @Rsi 

LD Rd, address 
LDB Rbd, address 

LDL RRd, address 








3 
5 

7 
11 

9 
12 










10 


10000 


w 


Rs 


Rd 






10 


10000 W 


Rs 


Rd 


3 




















10 


010100 


RRs 


RRd 






10 


010100 


RRs 


RRd 


5 


IR: 
















00 


1 0000 


w 


Rs^O 


Rd 






00 


1 0000 


W 


RS9tO 


Rd 


7 




















00 


0101 00 


Rs^O 


RRd 






00 


01 01 00 


RS:itO 


RRd 


11 


DA: 
















01 


1 0000 


w 


0000 


Rd 




SS 


01 


1 0000 


w 


0000 


Rd 1 


10 




address 





segment 


offset 




















SL 


01 


10000 


W 


0000 


Rd 






1 


segment 


0000 0000 


12 




offset 






















01 


010100 


0000 


RRd 




SS 


01 


010100 


0000 


RRd 


13 




address 





segment 


offset 




















SL 


01 


010100 


0000 


RRd 






1 


segment 


0000 0000 


15 




offset 1 





















Note 1: Word register in nonsegmented mode, register pair in segmented mode. 



6-62 



Load Register (Continued) 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LD Rd, addr(Rs) 
LDB Rbd, addr(Rs) 

LDL RRd, addr(Rs) 

LDRd, Rsl(#disp) 
LDB Rbd, Rsl(#disp) 

LDL RRd, Rsi(#disp) 

LDRd, Rsi(Rx) 
LDB Rd, Rsi(Rx) 

LDL RRd, Rsi(Rx) 








10 

13 

14 
17 

14 
17 








X: 




01 


10000 


W 


Rs*0 


Rd 




SB 


01 


1 0000 


W 


Rs^O 


Rd 


10 




address 





segment 


offset 




















SL 


01 


10000 


W 


Rs^O 


Rd 






1 segment 


0000 0000 1 


13 




offset 






















01 


010100 


Rs:^0 


RRd 




SS 


01 


010100 


Rs^tO 


RRd 


13 




address 





segment 


offset 




















SL 


01 


10100 


Rs^O 


RRd 1 






1 


segment 


0000 0000 


16 




offset 




BA: 
















00 


11000 


W 


Rs*0 


Rd 






00 


11000 


W 


Rs^O 


Rd 


14 




displacement 


displacement 




















00 


110101 


Rs^O 


Rd 






00 


110101 


RS9tO 


Rd 


17 




displacement 


displacement 


BX: 
















01 


11000 


W 


Rs*0 


Rd 






01 


11000 


W 


RS:^0 


Rd 


14 




0000 


Rx 


0000 0000 


0000 


Rx 


0000 0000 




















01 


11010 


1 


Rs*0 


Rd 






01 


11010 


1 


Rs?tO 


Rd 


17 




0000 


Rx 


0000 0000 


0000 


Rx 


0000 0000 

















Load Memory 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LD @Rdi, Rs 
LDB@Rdi, Rbs 

LDL@Rdi,RRs 

LD address, Rs 
LDB address, Rbs 








8 
11 

11 








IR: 




00 


10111 


W 


Rd :^ 


Rs 






00 


10111 


W 


Rd ^ 


- 


8 




















00 


011101 


Rd ^ 


RRs 






00 


011101 


Rd ^ 


RRs 


11 


DA: 
















01 


10111 


w 


0000 


„. 




SS 


01 


10111 


w 


0000 


Rs 1 


12 




address 





segment 


offset 




















SL 


01 


10111 


W 


0000 


Rs 






1 


segment 


0000 0000 


14 




offset 





















Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Load Memory (Continued) 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



DA: 



X: 



BA: 



BX: 



LDL address, RRs 



LD addr(Rd), Rs 
LDB addr(Rd), Rbs 



LDR addr(Rd), RRs 



LDRdl(#disp), Rs 
LDBRdl(#disp), Rbs 



LDL Rdi(#disp), RRs 



LD Rdi(Rx), Rs 
LDBRdl(Rx), Rbs 



LDL Rdi(Rx), RRs 



01 011101 0000 RRs 



address 



1 10111 W Rd:)t0 Rs 



address 



01 011101 Rd^O RRs 



00 1 1 001 W Rd*0 Rs 



displacement 



110111 Rd:)tO RRs 



displacement 



01 


11001 


W 


Rd*0 


Rs 


0000 


Rx 


0000 0000 



01 


110111 


Rd#0 


RRs 


0000 


Rx 


0000 0000 



14 



12 



15 



14 



17 



14 



17 



ss 


01 


011101 


0000 


RRs 





segment 


offset 








01 


1 01 1101 


0000 


RRs 


SL 


1 


segment 


0000 0000 




offset 






88 


01 


10111 


W 


Rd^i^O 


Rs 





segment 


offset 1 








01 


10111 


W 


Rd:^0 


Rs 


8L 


1 segment 


0000 0000 1 




offset 






88 


01 


011101 


Rd:^0 


RRs 1 





segment 


offset 








01 


011101 


Rd^O 


RRs 


8L 


1 


segment 


0000 0000 




offset 








00 


11001 


W 


Rd^O 


Rs 




displacement 








00 


1 1 1011 1 


Rd^O 


RRs 1 




displacement 








01 


11001 


W 


Rd^ito 


Rs 




0000 


Rx 


0000 0000 








01 


110111 


Rd^tO 


RRs 




0000 


Rx 


0000 0000 



15 



17 



12 



15 



15 



18 



14 



17 



14 



17 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Load Immediate Value 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



R: 



IR: 



DA: 



LD Rd, #data 



LDB Rbd, #data2 



LDL RRd, #data 



LD@Rdl, #data 



LDB@Rdl, #data 



LD address, #data 



LDB address, #data 



00 


100001 


0000 


Rd 


data 




00 


100000 


0000 


Rd 


data 


data 1 




1 100 


Rd 


data 




00 


010100 


0000 


RRd 


31 data (high) 16 


15 data (low) q 




00 


001101 


Rd ^ 


0101 


data 




00 


001 100 


Rd 9t 


0101 1 


data 


data 




01 


001101 


0000 


0101 


address 


data 



01 


001100 


0000 


0101 


address 


data 


data 



11 



11 



11 



14 



14 



00 100001 0000 Rd 



data 



00 100000 


0000 


Rd 


data 


data 



1 100 


Rd 


data 




00 


010100 


0000 


RRd 


31 data (high) 16 


15 data (low) o 



00 001101 Rd^O 0101 



data 



00 0011 00 



Rd ^ 0101 



data 



SS 



SL 



SS 



SL 



01 


001101 


0000 


01 01 





segment 


offset 


data 



01 


001101 


0000 


0101 


1 


segment 


0000 0000 


offset 


data 



01 


001100 


0000 


0101 





segment 


offset 


data 


data 



01 


001100 


0000 


0101 


1 


segment 


0000 0000 


offset 


data 


data 



11 



11 



11 



15 



17 



15 



17 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 

Note 2; Although two formats exist for "LDB R, IM", the assembler always uses the short format. In this case, the 
"src field" in the instruction format encoding contains the source operand. 
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Load Immediate Value (Continued) 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



X: 



LD addr(Rd), #data 



LDB addr(Rd), #data 



1 00 1101 Rd*0 101 



address 



01 


001100 


Rd^O 


0101 


address 


data 


data 



15 



15 



SS 



SL 



SS 



SL 



01 


001101 


Rd:^0 


0101 


segment 


offset j 


data 



01 


001101 


Rd^O 


0101 


1 


segment 


0000 0000 


offset 


data 



01 


001100 


Rd?^0 


0101 


segment 


offset 


data 


data 



01 


001100 


Rd*0 


0101 


1 


segment 


000 0000 


offset 


data 


data 



15 



18 



15 



18 



Example: Several examples of the use of the Load instruction are treated in detail in Chapter 4 

under addressing modes. 



LDA dst, src 



LDA 

Load Address 



dst: R 

src: DA, X, BA, BX 



Operation: 



dst -«- address (src) 



Flags: 



The address of the source operand is computed and loaded into the destination. The 
contents of the source are not affected. The address computation follows the rules for 
address arithmetic. The destination is a word register in nonsegmented mode, and a 
register pair in segmented mode. 

In segmented mode, the address loaded into the destination has an undefined value 
in all reserved bits (bits 16-23 and bit 31). However, this address may be used by- 
subsequent instructions in the indirect based or base- index addressing modes 
without any modification to the reserved bits. 

No flags affected 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



DA: 



LDA Rdi , address 



01 110110 0000 Rd 



X: 



LDARdi, addr(Rs) 



01 110110 Rs*0 



BA: 



BX: 



LDARdi, Rsl (#disp) 



LDARdi, Rsl (Rx) 



00110100 


RS:;tO 


Rd 


displacement 




01110100 


Rs*0 


Rd 


0000 


Rx 


0000 


0000 



12 



13 



15 



15 



ss 


01 


110110 


0000 


RRd 





segment 


offset 








01 


110110 


0000 


RRd 


SL 


1 segment 


0000 0000 1 




offset 






SS 


01 


110110 


Rs^O 


RRd 





segment 


offset 








01 


110110 


Rs^O 


RRd 


SL 


1 


segment 


0000 oooo] 




offset 








00110100 


Rs^O 


Rd 




displacement 








01110100 


RS9^0 


Rd 




0000 


Rx 


0000 0000 



13 



15 



13 



16 



15 



15 
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Examples: LDA R4, STRUCT !in nonsegmented mode, register R4 is loaded! 

iwith the nonsegmented address of the location! 
I named STRUCT! 

LDA RR2, «3» 8(R4) !in segmented mode, if index register R4! 

! contains %20, then register RR2 is loaded! 

iwith the segmented address («3», offset %28)! 
LDA RR2,RR4(#8) !in segmented mode, if base register RR4! 

! contains %0 1000020, then register RR2 is loaded! 

!with the segment address « 1 » %28! 

! (segment 1, offset %28)! 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 



LDAR 

Load Address Relative 



Operation: 



LDAR dst, src 


dst: R 




src: RA 


dst ■*- ADDRESS (src) 





Flags: 



The address of the source operand is computed and loaded into the destination. The 
contents of the source are not affected. The destination is a word register in 
nonsegmented mode, and a register pair in segmented mode. In segmented mode, 
the address loaded into the destination has all "reserved" bits (bits 16-23 and bit 31) 
cleared to zero. 

The relative addressing mode is calculated by adding the displacement in the 
instruction to the updated value of the program counter (PC) to derive the address. 
The updated PC value is taken to be the address of the instruction byte following the 
LDAR instruction, while the displacement is a 16-bit signed value in the range 
-32768 to +32767. The addition is performed following the rules of address 
arithmetic, with no modifications to the segment number in segmented mode. Thus 
in segmented mode, the source operand must be in the same segment as the LDAR 
instruction. 

The assembler automatically calculates the displacement by subtracting the PC value 
of the following instruction from the address given by the programmer. 

No flags affected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


RA: 


LDARRdi, address 








15 












00110100 


0000 


Rd 






00110100 


0000 


Rd 




15 




displacement 


displacement 



















Example: 



LDAR R2, TABLE 
LDAR RR4, TABLE 



!in nonsegmented mode, register R2 is loaded! 
!with the address of TABLE! 

!in segmented mode, register pair RR4 is! 

! loaded with the segmented address of TABLE,! 

! which must be in the same segment as the program! 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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LDCTL 

Load Control 



Privileged Instruction 



LDCTL dst, src 



dst: CTLR 
src: R 
or 

dst: R 
src: CTLR 



Operation: 



dst 



This instruction loads the contents of a general purpose register into a control 
register, or loads the contents of a control register into a general-purpose register. 
The control register may be one of the following CPU registers: 

FCW Flag and Control Word 

REFRESH Refresh Control 

PSAPSEG Program Status Area Pointer - segment number 

PSAPOFF Program Status Area Pointer - offset 

NSPSEG Normal Stack. Pointer - segment number 

NSPOFF Normal Stack Pointer - offset 

The operation of each of the variants of the instruction is detailed below. The ones 
which load data into a control register are described first, followed by the variants 
which load data from a control register into a general purpose register. Whenever 
bits are marked reserved, the corresponding bit in the source register must be either 
or the value returned by a previous load from the same control register. For com- 
patibility with future CPUs, programs should not assume that memory copies of con- 
trol registers contain Os, nor should they store data in reserved fields of memory 
copies of control registers. 



Load Into Control Register 

LDCTL FCW, Rs 

Operation: FCW (2:7) ^ Rs (2:7) 

FCW (11:15) — Rs (11:15) 





15 


14 


13 


12 


11 


10 9 8 




7 


6 


c 




4 


3 




2 


1 


Rs: 


1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 




„, 


' 


' 1 


' ' 


' ' 


' 


. 


■ ' 


rJ 


' 1 


' 


FCW: 


SEG 


S/N 


EPA 


VI 


NVI 




c 


Z 


s 


P/V 


D 


H 


' ^-^■,^< 



LDCTL REFRESH, Rs 



Operation: REFRESH(1:15)-^ Rs(l:15) 

Rs: 
REFRESH: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


1 


' ' 


^\ 


' ' 


■ 


■ 


' ' 


^. 


' ' 


' ' 


■ H 


' ' 


' ' 


^1 


re 


rate 


counter 


14. 
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Operation: 



LDCTL NSPSEG, Rs 
NSPSEG (0:15) ■*- Rs(0:15) 



15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Rs: 



NSPSEG: 



''fffyyTT 



ttTttTt? 



I I I I I 



In segmented mode, the NSPSEG register is the normal mode R14 and contains the 
segment number of the normal mode processor stack pointer which is otherwise 
inaccessible for system mode. 

In nonsegmented mode, RI4 is not used as part of the normal processor stack 
pointer. This instruction may not be used in nonsegmented mode. 

LDCTL NSPOFF, Rs 
NSP, Rs 



Operation: 



NSPOFF (0:15) ^- Rs(0:15) 





15 14 13 12 11 10 


3 


8 


7 


B 


5 ' 


» 


3 2 





Rs: 


1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 




., 1 w 1 1 w w V V ,r w u u 1 u 1 


FF: 


1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 



*NSP in nonsegmented mode 

In segmented mode, the NSPOFF register is R15 in normal mode and contains the 
offset part of the normal processor stack pointer. In nonsegmented mode, R15 is the 
entire normal processor stack pointer. 

In nonsegmented Z8002, the mnemonic "NSP" should be used in the assembly 
language statement, and indicates the same control register as the mnemonic 
"NSPOFF". 

LDCTL PSAPSEG, Rs 



Operation: 



PSAPSEG (8:14) ^- Rs(8:14) 



Rs: 



PSAPSEG: 



15 


14 13 12 11 10 


3 8 


7 


6 


5 


4 


3 


2 





1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


' 


' ' 


^ 


' ' 


' ' 


' \ 


' 1 


' 




segment number 





L 



J 



The PSAPSEG register may not be used in the nonsegmented Z8002. In the 
segmented Z8001, care must be exercised when changing the two PSAP register 
values so that an interrupt occurring between the changing of PSAPSEG and 
PSAPOFF is handled correctly. This is typically accomplished by first disabling 
interrupts before changing PSAPSEG and PSAPOFF. 
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Operation: 



LDCTL PSAPOFF, Rs 
PSAP, Rs 

PSAPOFF (8:15) ^- Rs(8:15) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Rs: 
TSAPOFF: 



u n n u u ir n u 



I'll I L 



offset (upper byte) 



l"y;"'u; ' 



*PSAP in nonsegmented mode 

In the nonsegmented Z8002, the mnemonic "PSAP" should be used in the assembly 
language statement and indicates the same control register as the mnemonic 
"PSAPOFF". In the segmented Z8001, care must be exercised when changing the 
two PSAP register values so that an interrupt occurring between the changing of 
PSAPSEG and PSAPOFF is handled correctly. This is typically accomplished by first 
disabling interrupts before changing PSAPSEG and PSAPOFF. The low order byte 
of PSAPOFF should be 0. 

Load From Control Register 

LDCTL Rd, FCW 



Operation: 



Rd (2:7) *- FCW (2:7) 

Rd (11:15) ^ FCW (11:15) (ZBOOl only) 

Rd (11:14) ^ FCW (11:14) (Z8002 only) 

Rd(0:l)-e- UNDEFINED 

Rd(8:10) ^ UNDEFINED 

Rd (15) -»- (Z8002 only) 



15 14 13 12 11 10 



5 4 3 2 10 



FCW: 



Rd: 



SEG 



t t ^' t t 



NVI 



J I I L 



T f Y y 1^ T 



-undefined - 



LDCTL Rd, REFRESH 

Operation: Rd (1:8) -.- REFRESH (1:8) 

Rd (0) •*- UNDEFINED 
Rd(9:15)-H- UNDEFINED 

15 14 13 12 11 10 9 



5 4 3 2 10 



REFRESH: 


re 


rate 


counter 








' 


' ' 


' 1 


' i 


,i, 


M 


' ' 


' 


Rd: 


U|t«t#fto«# 


1 1 1 1 1 1 1 
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LDCTL Rd, PSAPSEG 

Operation: Rd (8:14) ^ PSAPSEG (8:14) 

Rd (0:7) ^ UNDEFINED 
Rd (15) ^ UNDEFINED 





15 


14 13 12 11 10 


9 


3 


7 6 5 4 3 2 10 


PSAPSEG: 




segment number 


.;;.ttiljii.l£l.ii!i>!>i '.' >~^ ....'.ji^'.-J; 




•■ i i i 


Rd: 




1 1 1 1 1 1 





I 



■ undefined ' 



i 



This instruction may not be used in the nonsegmented version. 



LDCTL Rd, PSAPOFF 
Rd, PSAP 

Operation: Rd (8:15) ■*- PSAPOFF (8:15) 

Rd (0:7) «- UNDEFINED 



TSAPOFF 





15 14 13 12 11 10 


3 


5 


7 6 


5 4 3 2 


1 




offset (upper byte) 


'■':-^.:^-,v. /,.,,] 




' 


M 


' ' 


f ' 


' ' 


■• 


^ 


' ' 


- 


: 


1 1 1 1 ...L .1 , 1.,. 


undefined 



Operation: 



*PSAP in nonsegmented mode 

In nonsegmented mode, the mnemonic PSAP should be used in the assembly- 
language statement, and it indicates the same control register as the mnemonic 
PSAPOFF. 

LDCTL Rd, NSPSEG 
Rd(0:15) ^- NSPSEG (0:15) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



NorSECr: , , i i i i i i i 


' 




■\^ 


. 


' ' 


' ' 


.. 


' ' 


^1 


' ' 


' ' 


\ 


' ' 


' ' 


^ 


°' 1 1 1 1 1 1 II 1 1 „ 1 1 , 1 , 1... 1 . 



This instruction is not available in nonsegmented mode. 
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LDCTL Rd, NSPOFF 
Rd, NSP 



Operation: 



Rd(0:15) ■*- NSPOFF (0:15) 

151413121110 9 8 7 6 5 4 3 2 1 



*NSPOFF: 



Rd: 



TTTTYyyTyTyTyTTT 



I I I I I I I I I I I I 



Flags: 



*NSP in nonsegmented mode 

In nonsegmented mode, the mnemonic NSP should be used in the assembly 
language statement, and it indicates the same control register as the mnemonic 
NSPOFF. 

No flags affected, except when the destination is the Flag and Control Word (LDCTL 
FCW, Rs), in which case all the flags are loaded from the source register. 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDCTL FCW, Rs 

LDCTL REFRESH, Rs 

LDCTL PSAPSEG, Rs 

LDCTL PSAPOFF, Rs 
PSAP, Rs 

LDCTL NSPSEG, Rs 

LDCTL NSPOFF, Rs 
NSP, Rs 








7 

7 

7 
7 














01111101 


Rs 


1010 






01111101 


Rs 


1010 




7 






















01111101 


Rs 


1011 






01111101 


RS 


1011 




7 
























01111101 


Rs 


1 100 




7 






















01111101 


Rs 


1101 






01111101 


Rs 


1101 




7 
























01111101 


Rs 


1110 




7 






















01111101 


Rs 


1111 






01111101 


Rs 


1111 




7 


















Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDCTL Rd, FCW 

LDCTL Rd, REFRESH 

LDCTL Rd, PSAPSEG 

LDCTL Rd, PSAPOFF 
LDCTL Rd, PSAP 
LDCTL Rd, NSPSEG 

LDCTL Rd, NSPOFF 
Rd, NSP 








7 
7 

7 

7 














01111101 


Rd 


0010 






01111101 


Rd 


001 


























01111101 


Rd 


001 1 






01111101 


Rd 


001 1 




























01111101 


Rd 


0100 


























01111101 


Rd 


0101 






01111101 


Rd 


0101 




























01111101 


Rd 


01 10 


























111110 1 


Rd 


0111 






01111101 


Rd 


0111 
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LDCTLB 

Load Control Byte 



LDCTLB dst, src 



dst: FLAGS 

src: R 

or 

dst: R 

src: FLAGS 



Operation: 



dst -«- src 



This instruction is used to load the FLAGS register or to transfer its contents into a 
general-purpose register. Note that this is not a privileged instruction. 



Load Into FLAGS Register 

LDCTLB FLAGS, Rbs 
FLAGS (2:7) ^- src (2:7) 



The contents of the source (a byte register) are loaded into the FLAGS register. The 
lower two bits of the FLAGS register and the entire source register are unaffected. 



7 6 5 4 3 2 1 



Rbs: 



FLAGS: 



1 1 1 1 1 




1 


' 


' ' 


' ' 


' ' 


i. 


•^ 


' 


c 


Z 1 s 


P/V 


D 


H 





reserved 



Load From FLAGS Register 

LDCTLB Rbd, FLAGS 

dst (2:7) ^- FLAGS (2:7) 
dst (0:1) ^- 



The contents of the upper six bits of the FLAGS register are loaded into the destina- 
tion (a byte register). The lower two bits of the destination register are cleared to 
zero. The FLAGS register is unaffected. 



FLAGS: 



Rbd: 



7 












* 




3 


2 


1 


C 


Z 


s 


P/V 


D 


H 




1 


i. 


' ' 


■ ^ 


' ' 


' ' 


' 


11111 




1 



Flags: 



When the FLAGS register is the destination, all the flags are loaded from the 
source. When the FLAGS register is the source, none of the flags are affected. 
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Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDCTLB FLAGS, Rbs 
LDCTLB Rbd, FLAGS 








7 
7 














1 0001 1 00 


Rs 


1001 






10001 100 


Rs 


1 001 




7 






















1 0001 1 00 


Rd 


0001 




1 0001 1 00 


Rd 


0001 




7 
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LDD 

Load and Decrement 



LDD dst, src, r 
LDDB 



dst: IR 
src: IR 



Operation: dst ■*- src 

AUTODECREMENT dst and src (by 1 if byte, by 2 if word) 
r -*- r - 1 



Flags: 



This instruction is used for block transfers of strings of data. The contents of the loca- 
tion addressed by the source register are loaded into the location addressed by the 
destination register. The source and destination registers are then decremented by 
one if LDDB, or by two if LDD, thus moving the pointers to the previous elements in 
the strings. The source destination, and counter registers must be separate and non- 
overlapping registers. The word register specified by "r" (used as a counter) is then 
decremented by one. 

C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDD @Rsi, @Rdl, r 
LDDB @Rsi , @Rdl , r 








20 










IR: 




1011101 


W 


Rs ^0 


1001 






1011101 


W 


Rs^O 


1001 




20 




0000 


r 


Rd 7t 


1000 


0000 


r 


Rd 9t 


1000 



















Example: 



In nonsegmented mode, if register Rl contains %202A, register R2 contains %404A, 
the word at location %404A contains %FFFF, and register R3 contains 5, 
the instruction 

LDD@R1, @R2, R3 

will leave the value %FFFF at location %202A, the value %2028 in Rl, the value 
%4048 in R2, and the value 4 in R3. The V flag will be cleared. In segmented mode, 
register pairs would be used instead of Rl and R2. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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LDDR 

Load, Decrement and Repeat 



LDDR dst, src, r 
LDDRB 



dst: IR 
src: IR 



Operation: dst -*- src 

AUTODECREMENT dst and src (by 1 if byte, by 2 if word) 
r -^ r - 1 
repeat until r = 

This instruction is used for block transfers of strings of data. The contents of the loca- 
tion addressed by the source register are loaded into the location addressed by the 
destination register. The source and destination registers are then decremented by 
one if LDDRB, or by two if LDDR, thus moving the pointers to the previous elements 
in the strings. The word register specified by "r" (used as a counter) is then 
decremented by one. The entire operation is repeated until the result of decremen- 
ting r is zero. The source, destination, and counter registers must be separate and 
non-overlapping registers. This instruction can transfer from 1 to 65536 bytes or from 
1 to 32768 words (the value for r must not be greater than 32768 for LDDR). 

The effect of decrementing the pointers during the transfer is important if the source 
and destination strings overlap with the source string starting at a lower memory 
address. Placing the pointers at the highest address of the strings and decrementing 
the pointers ensures that the source string will be copied without destroying the 
overlapping area. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
reguest is accepted, so that the instruction can be properly resumed. Seven cycles 
should be added to this instruction's execution time for each interrupt reguest that Is 
accepted. 



Flags: 



C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 


IR: 


LDDR @Rdi, @Rsl, r 
LDDRB @Rdl, @Rsi, r 








11+9n 












1011101 


W 


Rs 


1001 






1011101 


W 


Rs 


1 001 




11+9n 




0000 


r 


Rd 


0000 


0000 


r 


Rd 


0000 
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Example: In nonsegmented mode, if register Rl contains %202A, register R2 contains %404A, 

the words at locations %4040 through %404A all contain %FFFF, and register R3 
contains 6, the instruction 

LDDR @R1, @R2, R3 

will leave the value %FFFF in the words at locations %2020 through %202A, the 
value %201E in Rl, the value %403E in R2, and in R3. The V flag will be set. In 
segmented mode, register pairs would be used instead of Rl and R2. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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LDI 

Load and Increment 



LDI dst, src, r 
LDIB 



dst: IR 
src: IR 



Operation: dst -*- src 

AUTOINCREMENT dst and src (by 1 if byte, by 2 if word) 
r -^ r - 1 



Flags: 



This instruction is used for block transfers of strings of data. The contents of the loca- 
tion addressed by the source register are loaded into the location addressed by the 
destination register. The source and destination registers are then incremented by 
one if LDIB, or by two if LDI, thus moving the pointers to the next elements in the 
strings. The source, destination, and counter registers must be separate and non- 
overlapping registers. The word register specified by "r" (used as a counter) is then 
decremented by one. 

C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero, cleared otherwise 

D; Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDI@Rdl, @Rsl, r 
LDIB@Rdl,@Rsl, r 








20 










IR: 




1011101 


W 


Rs^to 


0001 






1011101 


W 


Rs ^0 


0001 








0000 


r 


Rcl#0 


1000 


0000 


r 


Rd=^0 


1 000 


20 



















Example: 



This instruction can be used in a "loop" of instructions which transfers a string of 
data from one location to another, but an intermediate operation on each data ele- 
ment is reguired. The following sequence transfers a string of 80 bytes, but tests for 
a special value (%0D, an ASCII return character) which terminates the loop if 
found. This example assumes nonsegmented mode. In segmented mode, register 
pairs would be used instead of Rl and R2. 



LOOP: 



LD 

LDA 

LDA 


R3, #80 
Rl, DSTBUF 
R2, SRCBUF 


Unitialize counter! 
!load start addresses! 


CPB 
JR 

LDIB 
JR 


@R2, #%0D 
EQ, DONE 
@R1, @R2, R3 
NOV, LOOP 


! check for return character 

!exit loop if found! 

! transfer next byte! 

! repeat until counter = 0! 



DONE: 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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LDIR 

Load, Increment and Repeat 



LDIR 

Load, Increment and Repeat 



LDIR dst, src, r 
LDIRB 



dst: IR 
src: IR 



Operation: dst -*- src 

AUTOINCREMENT dst and src (by 1 if byte; by two if word) 
r -^ r - 1 
repeat until R = 

This instruction is used for block transfers of strings of data. The contents of the loca- 
tion addressed by the source register are loaded into the location addressed by the 
destination register. The source and destination registers are then incremented by 
one if LDIRB, or by two if LDIR, thus moving the pointers to the next elements in the 
strings. The word register specified by "r" (used as a counter) is then decremented 
by one. The entire operation is repeated until the result of decrementing r is zero. 
The source, destination, and counter registers must be separate and non-overlapping 
registers. This instruction can transfer from 1 to 65536 bytes or from 1 to 32768 
words (the value for r must not be greater than 32768 for LDIR) . 

The effect of incrementing the pointers during the transfer is important if the source 
and destination strings overlap with the source string starting at a higher memory 
address. Placing the pointers at the lowest address of the strings and incrementing 
the pointers ensures that the source string will be copied without destroying the 
overlapping area. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven cycles 
should be added to this instruction's execution time for each interrupt request that is 
accepted. 



Flags: 



C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles^ 


IR: 


LDIR @Rdl, @Rsl, r 
LDIRB @Rdi, @Rsi, r 








11+9n 












1011101 


W 


Rs ;t 


0001 






1011101 


W 


Rs ^0 


0001 




11+911 




0000 


r 


Rd^O 


0000 


0000 


r 


Rd*0 


0000 
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Example: The following sequence of instructions can be used in nonsegmented mode to copy a 

buffer of 512 words (1024 bytes) from one area to another. The pointers to the start of 
the source and destination are set, the number of words to transfer is set, and then 
the transfer takes place. 

LDA Rl, DSTBUF 

LDA R2, SRCBUF 

LD R3, #512 

LDIR @R1, @R2, R3 

In segmented mode, Rl and R2 must be replaced by register pairs. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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LDK 

Load Constant 



LDK dst, src 



dst: R 
src: IM 



Operation: 



dst •«- src (src = to 15) 



Flags: 



The source operand (a constant value specified in the src field) is loaded into the 
destination register. The source operand is a value from to 15. It is loaded into the 
four low-order bits of the destination register, while the high-order 12 bits are 
cleared to zero. 

No flags affected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


LDK Rd, #data 








5 












10 


111101 


Rd 


data 






1 


111101 


Rd data 




5 



















Example: 



To load register R3 with the constant 
LDK R3,#9 
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LDM 

Load Multiple 



LDM dst, src, n 



dst: R 

src: IR, DA, X 

or 

dst: IR, DA, X 

src: R 



Operation: 



dst ■*- src(n words) 



Flags: 



The contents of n source words are loaded into the destination. The contents of the 
source are not affected. The value of n lies between I and 16, inclusive. This instruc- 
tion moves information between memory and registers; registers are accessed in 
increasing order starting with the specified register; RO follows R15. The instruction 
can be used either to load multiple registers into memory (e.g. to save the contents 
of registers upon subroutine entry) or to load multiple registers from memory (e.g. to 
restore the contents of registers upon subroutine exit). 

The instruction encoding contains values from to 15 in the "num" field correspond- 
ing to values of 1 to 16 for n, the number of registers to be loaded or saved. 

The starting address is computed once at the start of execution, and incremented by 
two for each register loaded. If the original address computation involved a register, 
the register's value will not be affected by the address incrementation during 
execution. Similarly, modifying that register during a load from memory will not 
affect the address used by this instruction. 

No flags affected 



Load Multiple - Registers From Memory 
















Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDMRd, @Rsi, #n 
LDM Rd, address, #n 








11+3n 
14 + 3n 








IR: 




00 011100 


Rs^O 


0001 






00 011100 


RS:^0 


0001 


11+3n 




Rd 


0000 


num 


Rd 


0000 


num 
















DA: 




01 011100 


0000 


0001 




SS 


01 011100 


0000 


0001 






Rd 


0000 


num 


Rd 


0000 


num 


15 + 3n 




address 





segment 


offset 






















SL 


01 011100 


0000 


0001 






Rd 


0000 


num 


17 + 3n 




1 


segment 


0000 0000 






offset I 
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Load Multiple - Registers From Memory (Continued) 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



X: 



LDM Rd, addr(Rs), #n 



01 


011100 


Rs^tO 


0001 


0000 


Rd 


0000 


num 


address 



15 + 3n 





01 


011100 


Rs 4- 


0001 


ss 


0000 


Rd 


0000 


num 







segment 


offset 1 








01 


011100 


Rs^jtO 


0001 


SL 


0000 


Rd 


0000 


num 


1 


segment 


0000 0000 




offset 



15 + 3n 



18 + 3n 



Load Multiple - Memory From Registers 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



DA: 



LDM@Rdl, Rs, #n 



LDM address, Rs, #n 



00 


011100 


Rd9t0 


1001 


0000 


Rs 


0000 


num 




01 


011100 


0000 


1001 


0000 


Rs 


0000 


num 


address 



11+3n 



14 + 3n 



00 


011100 


Rd*0 


1001 


0000 


Rs 


0000 


num 



LDM addr(Rd), Rs, #n 



01 


011100 


Rd#0 


1001 


0000 


Rs 


0000 


num 


address 



15 + 3n 



SS 



SL 



SS 



SL 



01 


011100 


0000 


1001 


0000 


Rs 


0000 


num 





segment 


offset 



01 


1110 


0000 


1 001 


0000 


Rs 


0000 


num 


1 


segment 


0000 0000 


offset 



01 


011100 


Rd*0 


1 001 


0000 


Rs 


0000 


num 





segment 


offset 



01 


011100 


Rd*0 


1 001 


0000 


Rs 


0000 


num 


1 


segment 


0000 0000 1 


offset 



11+3n 



15 + 3n 



17 + 3n 



15 + 3n 



18 + 3n 



Example: In nonsegmented mode, if register R5 contains 5, R6 contains %0100, and R7 con- 

tains 7, the statement 

LDM @R6, R5, #3 

will leave the values 5, %0100, and 7 at word locations %0100, %0102, and %0104, 
respectively, and none of the registers will be affected. In segmented mode, a 
register pair would be used instead of R6. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2; n = number of registers. 
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LDPS 

Load Program Status 



Privileged Instruction 



LDPS src 



src: IR, DA, X 



Operation: 



PS ■<- src 



The contents of the source operand are loaded into the Program Status (PS), loading 
the Flags and Control Word (FCW) and the program counter (PC). The new value 
of the FCW does not become effective until the next instruction, so that the status 
pins will not be affected by the new control bits until after the LDPS instruction 
execution is completed. The next instruction executed is that addressed by the new 
contents of the PC. The contents of the source are not affected. 

This instruction is used to set the Program Status of a program and is particularly 
useful for setting the System/Normal mode of a program to Normal mode, or for run- 
ning a nonsegmented program in the segmented Z8001 version. The PC segment 
number is not affected by the LDPS instruction in nonsegmented mode. 

The format of the source operand (Program Status block) depends on the current 
Segmentation mode (not on the version of the Z8000) and is illustrated in the 
following figure: 







NONSEGMENTED 


LOW ADDRESS 


SEGMENTED 










FCW 




hlfC-t^Lc:- 


'i 




PC 


FCW 












PC SEG. NO. 






HIGH ADDRESS 


PC OFFSET 






(shaded area is reserved — must be 


zero) 


Flags: 


All flags are loaded from the source operand. 


Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


LDPS @Rsi 
LDPS address 

LDPS addr(Rs) 








|2 
16 

17 










00 


111001 


Rs*0 


0000 




[oo 


1 1 1001 


Rs^O 


0000 


16 


DA: 














01 


1110 1 


0000 


0000 




88 


01 


111001 


0000 


oooo| 


20 




address 





segment 


offset 




















8L 


01 


111001 


0000 


0000 






1 


segment 


0000 0000 


22 




offset 




X: 
















01 


111001 


Rs*0 


0000 




88 


01 


1 1 1 001 


Rs^tO 


0000 


20 




address 





segment 


offset 




















SL 


01 


1110 01 


Rs^O 


0000 






1 


segment 


0000 0000 


23 




offset 






























6 


-86 














D3-8003-0934 



Example: In the nonsegmented Z8002 version, if the program counter contains %2550, register 

R3 contains %5000, location o/o5000 contains %1800, and location %5.002 contains 
%A000, the instruction 

LDPS @R3 

will leave the value %A000 in the program counter, and the FCW value will be 
%1800 (indicating Normal Mode, interrupts enabled, and all flags cleared.) In the 
segmented mode, a register pair is used instead of R3. Note: Word register is used 
in nonsegmented mode, register pair in segmented mode. 
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LDR 

Load Relative 



LDR dst, src 

LDRB 

LDRL 



dst: R 
src: RA 
or 

dst: RA 
src: R 



Operation: 



dst 



Flags: 



The contents of the source operand are loaded into the destination. The contents of 
the source are not affected. The relative address is calculated by adding the 
displacement in the instruction to the updated value of the program counter (PC) 
to derive the operand's address. In segmented mode, the segmented number of the 
computed address is the same as the segment number of the PC. The updated PC 
value is taken to be the address of the instruction byte following the LDR, LDRB, or 
LDRL instruction, while the displacement is' a 16-bit signed value in the range 
-32768 to +32767. 

Status pin information during the access to memory for the data operand will be Pro- 
gram Reference, (1100) instead of Data Memory request (1000). 

The assembler automatically calculates the displacement by subtracting the PC value 
of the following instruction from the address given by the programmer. 

This instruction must be used to modify memory locations containing program infor- 
mation, such as the Program Status Area, if program and data space are allocated to 
different segments. 

No flags affected 



Load Relative Register 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


RA: 


LDR Rd, address 
LDRB Rbd, address 

LDRL RRd, address 








14 
17 












001 1000 


W 


0000 


Rd 






001 1 000 


W 


0000 


Rd 




14 




displacement 


displacement 






















00110101 


0000 


Rd 






00110101 


0000 


Rd 




■17 




displacement 


displacement 





















Load Relative Memory 



Example: 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




LDR address, Rs 
LDRB address, Rbs 

LDRL address, RRs 








14 
17 










RA: 




0011001 


w 


0000 


Rs 






0011001 


w 


0000 


Rs 




14 




displacement 


displacement 






















00110111 


0000 


Rs 






0011011 1 


0000 


Rs 




17 




displacement 


displacement 



















LDR R2, DATA 



[register R2 is loaded with the value in the! 
! location named DATA! 



MBIT 

Multi-Micro Bit Test 



Privileged Instruction 



MBIT 



Operation: 



1 if MI high (inactive); otherwise 



Flags: 



This instruction is used to synchronize multiple processors' exclusive access to 
shared hardware resources. The multi-micro input pin (MI) is tested, and the S flag 
is cleared if the pin is low (active); otherwise, the S flag is set, indicating that the 
pin is high (inactive). 

After the MBIT instruction is executed, the S flag can be used to determine whether 
a reguested resource is available or not. If the S flag is clear, then the resource is 
not available; if the S flag is set, then the resource is available for use by this CPU. 

C: Unaffected 

Z: Undefined 

S: Set if MI is high; cleared otherwise 

V: Unaffected 

D: Unaffected 

H: Unaffected 





Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 






Instruction Format 


Cycles 


Instruction Format 


Cycles 




MBIT 








7 










01111011 00001 01 




1 0111101100001010 1 


7 















Example: The following seguence of instructions can be used to wait for the availability of a 

resource. 

LOOP: 

MBIT Itest multi-micro input! 

JR PL, LOOP ! repeat until resource is available! 
AVAILABLE: 
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Privileged Instruction 



MREQ 

Multi-Micro Request 



MREQ dst dst: R 

Operation: Z ■*- 

if MI low (active) then S -»- 

MO forced high (inactive) 
else MO forced low (active) 

repeat dst -*- dst - 1 until dst = 
if MI low (active) then S -^ 1 
else S -*- 

MO forced high (inactive) 
Z^ 1 

This instruction is used to synchronize multiple processors' exclusive access to 
shared hardware resources. A reques t for a resource is signalled through the multi- 
micro input and output pins (MI and MO), with the S and Z flags indicating the 
availability of the resource after the MREQ instruction has been executed. 

First, the Z flag is cleared. T hen the MI pin is tested. If the MI pin is low (active), 
the S flag is cleared and the MO pin is forced high (inactive), thus indicating that the 
reso urce is not available and removing any previous request by the CPU from the 
MO line. 

If the MI pin is high (inactive), indicating that the reso urce may be available, a 
sequence of machine operations occurs. First, the MO pin is forced low (active), 
signalling a request by the CPU for the resource. Next, a finite delay to allow for 
propagation of the signal to other processors is accomplished by repeatedly 
decrementing the contents of the destination (a word register) until its value is zero. 
Then the MI pin is tested to determine whether the request for the resource was 
acknowledged. If the MI pin is low (active), the S flag is set to one, indicating that 
the resource is available and access i s gr anted. If the MI pin is still high (inactive), 
the S flag is cleared to zero, and the MO pin is forced high (inactive), in dica ting 
that the request was not granted and removing the request signal for the MO. 
Finally, in either case, the Z flag is set to one, indicating that the original test of the 
MI pin caused a request to be made. 

S flag Z flag MO Indicates 



high Request not signalled 

(resource not available) 

1 high Request not granted 

(resource not available) 
1 low Request granted 

(resource available) 



Flags: C: Unaffected 

Z: Set if request was signalled; cleared otherwise 

S: Set if request was signalled and granted; cleared otherwise 

V: Unaffected 

D: Unaffected 

H: Unaffected 
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Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mo<l@ 


Instruction Format 


Cycles^ 


Instruction Format 


Cycles^ 


R: 


MREQ Rd 




12 + 7n 






|01 11 101 1 1 Rd 1101 


|oi 111011 Rd 1101 


12 + 7n 











Example: 



TRY: 



LD R0,#50 

MREQ RO 



! allow for propagation delay! 

! multi-micro request with delay! 

!in register RO! 
JR MI, AVAILABLE 
JR Z,NOT_GR ANTED 

NOT_A VAIL ABLE: ■ ! resource not available! 



NOT_GR ANTED: 

JR TRY 
AVAILABLE: 

MRES 



! request not granted! 



!try again after awhile! 
!use resource! 



! release resource! 



Note 1: If the request is made, n = number of times the destination is decremented. If the request is not made, 
n = 0. 
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Privileged Instruction 



MRES 

Multi-Micro Reset 



MRES 



Operation: 



MO is forced high (inactive) 



This instruction is used to synchronize multiple process ors' e xclusive access to 
shared hardware resources. The multi-micro output pin MO is forced high (inactive). 
Forcing MO high (inactive) indicates that a resource controlled by the CPU is 
available for use by other processors. 



Flags: 


No flags affected. 










Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




MRES 






5 








01111011 00001 001 


01111011 00001 001 


5 











Example: 



MRES 



! signal that resource controlled by this CPU! 
lis available to other processors! 
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MSET 

Multi-Micro Set 



Privileged Instruction 



MSET 



Operation: 



MO is forced low (active) 



This instruction is used to synchronize multiple process ors' e xclusive access to 
shared hardw are resources. The multi-micro output pin MO is forced low (active). 
Forcing MO low (active) is used either to indicate that a resource controlled by the 
CPU is not available to other processors, or to signal a request for a resource con- 
trolled by some other processor. 



Flags: 


No flags affected 




















Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




MSET 








5 












01111011 00001 000 






01111011 


00001 000 




5 

















Example: 



MSET 



!CPU controlled resource not available! 
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MULT 

Multiply 



MULT dst, src dst: R 

MULTL src: R, IM, IR, DA, X 



Operation: Word 

dst (0:31) *- dst (0:15) X src (0:15) 

Long 

dst (0:63) ■*- dst (0:31) x src (0:31) 

The low-order half of the destination operand (multiplicand) is multiplied by the 
source operand (multiplier) and the product is stored in the destination. The con- 
tents of the source are not affected. Both operands are treated as signed, two's com- 
plement integers. For MULT, the destination is a register pair and the source is a 
word value; for MULTL, the destination is a register quadruple and the source is a 
long word value. 

For proper instruction execution, the "dst field" in the instruction format encoding 
must be even for MULT and must be a multiple of 4 (0, 4, 8, 12) for MULTL. If the 
source operand in MULTL is a register, the "src field" must be even. 

The initial contents of the high-order half of the destination register do not affect the 
operation of this instruction and are overwritten by the result. The carry flag is set to 
indicate that the upper half of the destination register is required to represent the 
result; if the carry flag is clear, the product can be correctly represented in the same 
precision as the multiplicand and the upper half of the destination merely holds a 
sign extension. 

The following table gives execution times for word and long word operands in each 
possible addressing mode. 

src Word Long Word 

NS SS SL NS SS SL 

282-h7*n 282-l-7*n 282 + 7*n 

282 + 7*n 282 + 7*n 282 + 7*n 

282 + 7*n 282 + 7*11 282 + 7*n 

283 + 7*n 284 + 7*n 286-H7*n 

284 + 7*n 284 + 7*n 287+7*n 

(n = number of bits equal to one in the absolute value of the low-order table 32 bits of the destination operand) 

When the multiplier is zero, the execution time of Multiply is reduced to the following times: 
src Word Long Word 



R 


70 


70 


70 


IM 


70 


70 


70 


IR 


70 


70 


70 


DA 


71 


72 


74 


X 


72 


72 


75 





NS 


SS 


SL 


NS 


SS 


SL 


R 


18 


18 


18 


30 


30 


30 


IM 


18 


18 


18 


30 


30 


30 


IR 


18 


18 


18 


30 


30 


30 


DA 


19 


20 


22 


31 


32 


34 


X 


20 


20 


23 


32 


32 


35 



Flags: C: MULT — set if product is less than -2-^1 or greater than or equal to 2^^; cleared 

otherwise; MULTL — set if product is less than 2^1 or greater than or equal to 2^1; 
cleared otherwise 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Cleared 

D: Unaffected 

H: Unaffected 
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Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles^ 



Segmented Mode 



Instruction Format 



Cycles^ 



R: 



IM: 



IR: 



DA: 



X: 



MULT RRd, Rs 
MULTL RQd, RRs 
MULT RRd, #data 

MULTL RQd, #data 

MULT RRd, @Rsi 
MULTL RQd, @Rsi 
MULT RRd, address 



MULTL RQd, address 



MULT RRd, addr(Rs) 



MULTL RQd, addr(Rs) 



01 011000 0000 Rd 



address 



01 011001 Rs^O Rd 



01 011000 Rst^O 



address 



10 


01 1001 


Rs 


Rd 




h« 


011000 


Rs 


Rd 




00 


011001 


0000 


Rd 


data 




00 


011000 


0000 


Rd 


31 data (high) 


16 


15 data (low) 







00 


011001 


Rs?tO 


Rd 




|oo 


011000 


RsTtO 


Rd 




01 


011001 


0000 


Rd 1 


address 



1 


011001 


Rs 


Rd 



|,0 


01 1000 


Rs 


Rd 1 



00 011001 0000 Rd 



data 



00 


01 1 000 


0000 


Rd 


31 


data (high) 


16 


15 


data (low) 






00 


0110 01 


Rs^O 


Rd 



00 


01 1 000 


RST^O 


Rd 



88 



8L 



88 



8L 



88 



8L 



88 



8L 



01 


011001 


0000 


Rd 





segment 


offset 



01 


011001 


0000 


Rd 


1 segment 


0000 oooo| 


offset 



01 


01 1 000 


0000 


Rd 





segment 


offset 



01 


01 1 000 0000 


Rd 


1 


segment 


0000 0000 


offset 



01 


011001 


Rs^O 


Rd 





segment 


offset 



01 


011001 


Rs*0 


Rd 


1 segment 


0000 0000 1 


offset 



01 


011000 


Rs^O 


Rd 





segment 


offset 



01 


01 1 000 


Rs9tO 


Rd 


1 


segment 


0000 0000 


offset 
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Example: If register RQO (composed of register pairs RRO and RR2) contains 

°/o 2222222200000031 (RR2 contains decimal 49), the statement 

MULTLRQ0,#10 

will leave the value %00000000000001EA (decimal 490) in RQO. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: Execution times for each instruction are given in the preceding tables. 
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NEG 

Negate 



NEG dst 
NEGB 



dst: R, IR, DA, X 



Operation: 



dst -*- dst 



Flags: 



The contents of the destination are negated, that is, replaced by its two's comple- 
ment value. Note that %8000 for NEG and %80 for NEGB are replaced by 
themselves since in two's complement representation the negative number with 
greatest magnitude has no positive counterpart; for these two cases, the V flag is set. 

C: Cleared if the result is zero; set otherwise, which indicates a "borrow" 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Set if the result is %8000 for NEG, or %80 for NEGB: cleared otherwise 

D: Unaffected 

H: Unaffected 



Example: 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




NEGRd 
NEGB Rbd 

NEG @Rdi 
NEGB @Rdi 

NEG address 
NEGB address 

NEG addr(Rd) 
NEGB addr(Rd) 








7 
12 

15 
16 








R: 




10 


00110 


W 


Rd 


0010 






10 


00110 


W 


Rd 


001 


7 
















IR: 




00 


00110 


W 


Rd^O 


0010 






00 


00110 


W 


Rd*0 


001 


12 
















DA: 




01 


00110 


W 


0000 


0010 




SS 


01 


00110 


W 


0000 


001 


16 




address 





segment 


offset 




















SL 


01 


looi 10 


W 


0000 


0010 






1 segment 


0000 oooo| 


18 




offset 




X: 
















01 


00110 


W 


Rd:;tO 


0010 




SS 


01 


00110 


W 


Rd:^0 


001 


16 




address 





segment 


offset 1 




















SL 


01 


00110 


w 


Rd?^0 


ooio| 






1 


segment 


00 00 0000 


19 




offset 



























If register R8 contains %051F, the statement 

NEG R8 
will leave the value %FAE1 in R8. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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NOP 

No Operation 



NOP 



Operation: 


No operation is performed. 








Flags: 


No flags affected 








Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




NOP 




7 








1 0001 101 000001 1 1 


10001101 00000111 


7 
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OR 

Or 



OR dst, src 
ORB 



dst: R 

src: R, IM, IR, DA, X 



Operation: 



dst '*- dst OR src 



Flags: 



The source operand is logically ORed with the destination operand and the result is 
stored in the destination. The contents of the source are not affected. The OR opera- 
tion results in a one bit being stored whenever either of the corresponding bits in the 
two operands is one; otherwise a zero bit is stored. 

C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

P: OR — unaffected; ORB — set if parity of the result is even; cleared otherwise 

D: Unaffected 

H: Unaffected 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


OR Rd, Rs 
ORB Rbd, Rbs 

OR Rd, #data 
ORB Rbd, #data 

OR Rd, @Rsl 
ORB Rbd, @Rsl 

OR Rd, address 
ORB Rbd, address 

OR Rd, addr(Rs) 
ORB Rbd, addr(Rs) 








4 

7 

7 

7 
9 

10 










10 00010 


W 


Rs 


Rd 






10 


00010 


W 


Rs 


Rd 


4 


IM: 
















00 


0001 01 


0000 


Rd 






00 


000101 


0000 


Rd 1 


7 




data 


data 




















00 


0001 00 1 0000 


Rd 






00 


1 0001 00 


0000 


Rd 1 


7 




data data 


data 


data 


IR: 
















00 


00010 


w 


Rs^O 


Rd 






00 


00010 


W 


Rs^tO 


Rd 


7 


DA: 
















01 


00010 


w 


0000 


Rd 




83 


01 


00010 


W 


0000 


Rd 


10 




address 





segment 


offset 




















SL 


01 


00010 


w 


0000 


Rd 1 






1 


segment 


0000 ooooj 


12 




offset 




X: 
















01 


00010 


w 


Rs:^0 


Rd 




SS 


01 


00010 


W 


Rs^O 


Rd 


10 






address 





segment 


offset 


















SL 


01 


00010 


w 


Rs*0 


Rd 






1 


segment 


0000 oooo] 


13 




address J 
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Example: If register RL3 contains %C3 (11000011) and the source operand is the immediate 

value %7B (01111011), the statement 

ORB RL3,#%7B 

will leave the value %FB (11111011) in RL3. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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Privileged Instruction 



OTDR 
(SOTDR) 

(Special) Output, Decrement and Repeat 



OTDR dst, src, r 


dst: IR 


OTDRB 


src: IR 


SOTDR 




SOTDRB 





Operation: dst -*- src 

AUTODECREMENT src (by 1 if byte, by 2 if word) 

r -«- r - 1 

repeat until r = 



Flags: 



This instruction is used for block output of strings of data. OTDR and OTDRB are 
used for normal I/O operation; SOTDR and SOTDRB are used for special I/O opera- 
tion. The contents of the memory location addressed by the source register are 
loaded into the I/O port addresses by the destination word register. I/O port 
addresses are 16 bits. The source register is then decremented by one if a byte 
instruction, or by two if a word instruction, thus moving the pointer to the previous 
element of the string in memory. The word register specified by "r" (used as a 
counter) is then decremented by one. The address of I/O port in the destination 
register is unchanged. The entire operation is repeated until the result of decrement- 
ing r is zero. This instruction can output from 1 to 65536 bytes or 32768 word (the 
value for r must not be greater than 32768 for OTDR or SOTDR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
request is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt request 
that is accepted. 

C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles^ 



Segmented Mode 



Instruction Format 



Cycles^ 



IR: 



OTDR @Rd,@Rsl, r 
OTDRB @Rd,@Rsi, r 

SOTDR @Rd,@Rsl, r 
SOTDRB @Rd,@Rsl, r 



0011101 


W 


Rs ^0 


101 S 


0000 


r 


Rd *0 


0000 



11+10n 



0011101 


W 


Rs it 


101 S 


0000 


r 


Rd #0 


0000 



11+10n 
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Example: In nonsegmented mode, if register Rll contains %OFFF, register R12 contains 

%B006, and R13 contains 6, the instruction 

OTDR @R11, @R12, R13 

will output the string of words from locations °/oB006 to %AFFC (in descending 
order of address) to port %OFFF. R12 will contain %AFFA, and R13 will contain 0. 
Rll will not be affected. The V flag will be set. In segmented mode, R12 would be 
replaced by a register pair. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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Privileged Instruction 



OTIR 
(SOTIR) 

(Special) Output, Increment and Repeat 



OTIR dst, src, r 
OTIRB 
SOTIR 
SOTIRB 



dst: IR 
src: IR 



Operation: dst -«- src 

AUTOINCREMENT src (by 1 if byte, by 2 if word) 
r -«- r — 1 
repeat until r = 

This instruction is used for block output of strings of data. OTIR and OTIRB are used 
for normal I/O operation; SOTIR and SOTIRB are used for special I/O operation. 
The contents of the memory location addressed by the source register are loaded 
into the I/O port addressed by the destination word register. I/O port addresses are 
16 bits. The source register is then incremented by one if a byte instruction, or by 
two if a word instruction, thus moving the pointer to the next element of the string in 
memory. The word register specified by "r" (used as a counter) is then decremented 
by one. The address of I/O port in the destination register is unchanged. The entire 
operation is repeated until the result of decrementing r is zero. This instruction can 
output from 1 to 65536 bytes or 32768 words (the value for r must not be greater than 
32768 for OTIR or SOTIR). 

This instruction can be interrupted after each execution of the basic operation. The 
program counter value of the start of this instruction is saved before the interrupt 
reguest is accepted, so that the instruction can be properly resumed. Seven more 
cycles should be added to this instruction's execution time for each interrupt reguest 
that is accepted. 



Flags: 



C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


OTIR @Rd, @Rsl, r 
OTIRB @Rd, @Rsl, r 
SOTIR @Rd, @Rsl, r 
SOTIRB @Rd, @Rsl, r 








11+10n 












0011101 


w 


RS :^0 


001 S 






0011 101 


w 


Rs ?t 


001S 




11 +10n 




0000 


r 


Rd^O 


0000 


0000 


r 


Rd :;fcO 


0000 
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Example: In nonsegmented mode, the following sequence of instructions can be used to output 

a string of bytes to the specified I/O port. The pointers to the I/O port and the start 
of the source string are set, the number of bytes to output is set, and then the output 
is accomplished. 



LD 


Rl, #PORT 


LDA 


R2, SRCBUF 


LD 


R3, #LENGTH 


OTIRB 


@R1, @R2, R3 



In segmented mode, a register pair would be used instead of R2. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements transferred. 
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OUT 
(SOUT) 

(Special) Output 



Privileged Instruction 



OUT dst, src 
OUTB 

SOUT dst, src 
SOUTB 



dst: IR, DA 
src: R 

dst: DA 
src: R 



Operation: 



dst ■*- src 



The contents of the source register are loaded into the destination, an Output or 
Special Output port. OUT and OUTB are used for normal I/O operation; SOUT and 
SOUTB are used for special I/O operation. 



Flags: 


No flags affected 




























Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




OUT ®Rd, Rs 
OUTB @Rd, Rbs 

OUT port, Rs 
OUTB port, Rbs 
SOUT port, Rs 
SOUTB port, Rbs 








10 
12 










IR: 




0011111 


W 


Rd:ii:0 


Rs 






0011111 


W 


Rd^O 


Rs 




10 


















DA: 




001 1 101 


W 


Rs 


oils 






0011101 


W 


Rs 


01 1 S 




12 




port 


port 










L_ 









Example: 



If register R6 contains %5252, the instruction 

OUT °/oll20, R6 
will output the value %5252 to the port %1120. 
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Privileged Instruction 



OUTD 
(SOUTD) 

(Special) Output and Decrement 



Operation: 



OUTD dst, src, r 




dst: 


IR 




OUTDB 




src: 


IR 




SOUTD 










SOUTDB 










dst •*- src 










AUTODECREMENT 


src 


(by 1 if byte 


, by 2 if 


word) 


r -*- r - 1 











Flags: 



This instruction is used for block output of strings of data. OUTD and OUTDB are 
used for normal I/O operation; SOUTD and SOUTDB are used for special I/O opera- 
tion. The contents of the memory location addressed by the source register are 
loaded into the I/O port addressed by the destination word register. I/O port 
addresses are 16 bits. The source register is then decremented by one if a byte 
instruction, or by two if a word instruction, thus moving the pointer to the previous 
element of the string in memory. The word register specified by "r" (used as a 
counter) is then decremented by one. The address of the I/O port in the destination 
register is unchanged. 

C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


OUTD @Rd, @Rsi , r 
OUTDB @Rd, @Rsl, r , 

SOUTD @Rd, @Rsi , r 
SOUTDB @Rd, @Rsl, r 








21 












001 1101 


W 


Rs :^ 


101S 






0011 101 


W 


Rs 9t 


1 01S 




21 




0000 


r 


Rd 


1000 


0000 


r 


Rd 


1 000 



















Example: 



In segmented mode, if register R2 contains the I/O port address %0030, register RR6 
contains % 12005552 (segment %12, offset %5552), the word at memory location 
% 12005552 contains %1234, and register R8 contains %1001, the instruction 

OUTD @R2, @RR6, R8 

will output the value %1234 to port %0030 and leave the value % 12005550 in RR6, 
and °/olOOO in R8. Register R2 will not be affected. The V flag will be cleared. In 
nonsegmented mode, a word register would be used instead of RR6. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 



6-107 



OUTI 
(SOUTI) 

(Special) Output and Increment 



Privileged Instruction 



OUTI dst, src, r 
OUTIB 
SOUTI 
SOUTIB 



dst: IR 
src: IR 



Operation: dst -*- src 

AUTOINCREMENT src (by 1 if byte, by 2 if word) 
r -^ r - 1 

This instruction is used for block output of strings of data. OUTI and OUTIB are 
used for normal I/O operation; SOUTI and SOUTIB are used for special I/O opera- 
tion. The contents of the memory location addressed by the source register are 
loaded into the I/O port addressed by the destination word register. I/O port 
addresses are 16-bit. The source register is then incremented by one if a byte 
instruction, or by two if a word instruction, thus moving the pointer to the next ele- 
ment of the string in memory. The word register specified by "r" (used as a counter) 
is then decremented by one. The address of the I/O port in the destination register is 
unchanged. 



Flags: 



C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



OUTI @Rd, @Rsi, r 
OUTIB @Rd, @Rsl, r 
SOUTI @Rd, @Rsl, r 
SOUTIB @Rd, @Rsl, r 



0011101 


W 


Rs # 


001S 


0000 


r 


Rd* 


1000 



21 



0011101 


w 


Rs^O 


0018 


0000 


r 


Rd#0 


1000 



21 
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Example: This instruction can be used in a "loop" of instructions which outputs a string of 

data, but an intermediate operation on each element is required. The following 
sequence outputs a string of 80 ASCII characters (bytes) with the most significant bit 
of each byte set or reset to provide even parity for the entire byte. Bit 7 of each 
character is initially zero. This example assumes nonsegmented mode. In segmented 
mode, R2 would be replaced with a register pair. 



LOOP: 



EVEN: 



DONE: 



LD 

LDA 

LD 

TESTE 

JR 

SETB 

OUTIB 
JR 



Rl, #PORT 
R2, SRCSTART 
R3, #80 

@R2 

PE, EVEN 

@R2, #7 

@R1, @R2, R3 
NOV, LOOP 



!load I/O address! 
Uoad start of string! 
! initialize counter! 

Itest byte parity! 

! force even parity! 

! output next byte! 

! repeat until counter = 0! 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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POP 

Pop 



POP dst, src 
POPL 



dst: R, IR, DA, X 
src: IR 



Operation: dst -«- src 

AUTOINCREMENT src (by 2 if word, by 4 if long) 



The contents of the location addressed by the source register (a stack pointer) are 
loaded into the destination. The source register is then incremented by a value 
which equals the size in bytes of the destination operand, thus removing the top ele- 
ment of the stack by changing the stack pointer. Any register except RO (or RRO in 
segmented mode) can be used as a stack pointer. 

With the POPL instruction, the same register cannot be used in both the source and 
destination addressing fields. 



Flags: 


No flags affected 


























Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


POP Rd, @Rsi 
POPL RRd, @Rsi 
POP@Rdi, @Rsi 
POPL@Rdi, @Rsi 
POP address, @Rsl 

POPL address, @Rsl 








8 
12 

12 
19 

16 
23 








10 


010111 


Rs ;t 


Rd. 






10 


010111 


Rs 9^ 


- 


8 




















10 


010101 


Rs ^ 


Rd 




10 


010101 


Rs :^ 


- 


12 


IR: 














00 


010111 


Rs#0 


Rd 9t 






00 


010111 


Rs:r'0 


Rd =f^o\ 


12 


















00 


010101 


Rs^O 


Rd *0 






00 


010101 


RS:^0 


Rd =^0 


19 


DA: 
















01 


010111 


Rs*0 


0000 




88 


01 


010111 


Rs#0 


oooo| 


16 




address 





segment 


offset 1 




















8L 


01 


010111 


RS:!&0 


0000 






1 


segment 


0000 0000 J 


19 




offset 






















01 


010101 


Rs^O 


0000 




88 


01 


010101 


RS:)t0 


ooooj 


23 




address 





segment 


offset 




















8L 


1 


010101 


Rs^aO 


ooooj 






1 


segment 


0000 0000 


26 




offset 

























6-110 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


X: 


POP addr(Rd), @Rsi 
POPL addr(Rd), @Rsl 








16 
23 










01 


010111 


Rs:^0 


Rd^^O 




SB 


01 


010111 


Rs^^O 


Rd:/:0 


16 




address 





segment 


offset 




















SL 


01 


010111 


Rs^^O 


Rd^to 1 






1 


segment 


0000 0000 


19 




offset 






















01 


010101 


RS9<=0 


Rd^tO 




SS 


01 


010101 


Rs^^O 


Rd^'O 1 


23 




address 





segment 


offset 




















SL 


01 


010101 


Rs#0 


Rd:^0 






1 segment 


0000 0000 1 


26 




offset 

























Example: 



In nonsegmented mode, if register R12 (a stack pointer) contains %1000, the word at 
location %1000 contains %0055, and register R3 contains %0022, the instruction 

POP R3, @R12 

will leave the value %0055 in R3 and the value %1002 in R12. In segmented mode, 
a register pair must be used as the stack pointer instead of R12. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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PUSH 

Push 



PUSH dst, src 
PUSHl 



dst: IR 

src: R, IM, IR, DA, X 



Operation: AUTODECREMENT dst (by 2 if word, by 4 if long) 

dst ■*- src 

The contents of the destination register (a stack pointer) are decremented by a value 
which equals the size in bytes of the source operand. Then the source operand is 
loaded into the location addressed by the updated destination register, thus adding a 
new element to the top of the stack by changing the stack pointer. Any register 
except RO (or RRO in segmented mode) can be used as a stack pointer. 

With PUSHL, the same register cannot be used for both the source and destination 
addressing fields. 



Flags: 



No flags affected 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



R: 



IM: 



IR: 



DA: 



PUSH@Rdi, Rs 
PUSHL @Rdi , RRs 

PUSH@Rdi, #data 

PUSH@Rdi, @Rsi 
PUSHL @Rdi , @Rsi 
PUSH C« Rdi , address 



PUSHL@Rdl, address 



10 


010011 


Rd^itO 


Rs 



10 


010 01 


Rd*0 


Rs 



00 001101 Rd^O 1001 



00 


010011 


Rd:^0 


Rs * 



00 


010001 


Rd^tO 


Rs * 




01 


01001 1 


Rd;tO 


0000 


address 



01 010001 Rd^^O 0000 



9 
12 

12 

13 
20 
14 



21 





10 010011 


Rd^O 


Rs 






10 


1 010001 


Rd:;tO 


- 






00 


001 101 


Rd^itO 


100l| 




data 1 








00 


010011 


Rd^O 


Rs :^ 








00 


010001 


Rd:^0 


Rs* o| 






ss 


01 


010011 


Rd^O 


0000 





segment 


offset 








01 


010011 


Rd^iO 


0000 


SL 


1 1 segment 


0000 0000 1 




offset 






SS 


01 


010001 


Rd^O 


0000 





segment 


offset 








01 


01 0001 


Rd:^0 


0000 


SL 


1 


segment 


0000 0000 




offset 



9 
12 

12 

13 
20 
14 

17 
13 
24 
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Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



X: 



PUSH@Rdl, addr(Rs) 



01 010011 Rd^eO RS:/:0 



address 



14 



PUSHL @Rdi , addr(Rs) 



01 010001 Rd^tO RS:itO 



address 



21 



SB 


01 


01001 1 


Rd:;t0 


Rs^itO 





segment 


offset { 








01 


010011 


Rd:)tO j Rs?t0 


SL 


1 


segment 


0000 0000 




offset 






88 


01 


010001 


Rd:^0 


Rs:^0 1 





segment 


offset 








01 


010001 


Rd?::0 


Rs:^0 1 


SL 


1 


segment 


0000 0000 




offset 1 



14 



17 



21 



24 



Example: In nonsegmented mode, if register R12 (a stack pointer) contains %1002, the word at 

location %1000 contains %0055, and register R3 contains %0022, the instruction 

PUSH @R12, R3 

will leave the value %0022 in location %100G and the value o/olOOO in R12. In 
segmented mode, a register pair must be used as the stack pointer instead of R12. 



Note 1: Word register is used in nonsegmented mode, register pair in segmented mode. 
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RES 

Reset Bit 



RES dst, src 
RESB 



dst: 


R, IR, DA, X 


src: 


IM 


or 




dst: 


R 


src: 


R 



Operation: 



dst(src) -«- 



Flags: 



This instruction clears the specified bit within the destination operand without 
affecting any other bits in the destination. The source (the bit number) can be 
specified as either an immediate value (Static), or as a word register which contains 
the value (Dynamic). In the second case, the destination operand must be a register, 
and the source operand must be RO through R7 for RESB, or RO through R15 for 
RES. The bit number is a value from to 7 for RESB, or to 15 for RES, with 
indicating the least significant bit. 

Only the lower four bits of the source operand are used to specify the bit number for 
RES, while only the lower three bits of the source operand are used with RESB. 
When the source operand is an immediate value, the "src field" in the instruction 
format encoding contains the bit number in the lowest four bits for RES, or the 
lowest three bits for RESB. 

No flags affected 



Reset Bit Static 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


RES Rd, #b 
RESB Rbd, #b 

RES@Rdi, #b 
RESB@Rdi, #b 

RES address, #b 
RESB address, #b 

RES addr(Rd), #b 
RESB addr(Rd), #b 








4 
11 

13 
14 










1 


1 0001 


w 


Rd 


b 






10 


1 0001 


W 


Rd 


b 


4 


IR: 
















00 


10001 


w 


Rd^O 


b 






00 


1 0001 


w 


Rd^to 


b 


11 


DA: 
















01 


1 0001 


w 


0000 


b 




SS 


01 


10001 


w 


0000 


b 


14 




address 





segment 


offset 




















SL 


01 


1 0001 


w 


0000 


^ 






1 


segment 


0000 0000 


16 




offset 




X: 
















01 


1 0001 


w 


Rd:;tO 


b 




SS 


01 


1 0001 


w 


Rd^O 


b 


14 




address 





segment 


offset 




















SL 


01 


|l 0001 


w 


Rd^tO 


- 






'1 


segment 


0000 0000 


17 




offset 
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Reset Bit Dynamic 


























Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




RES Rd, Rs 
RESB Rbd, Rs 








10 










R: 




00 1 0001 w 


0000 


Rs 






00 10001 w 


0000 


Rs 




10 




Rd 


0000 


0000 


Rd 


0000 


0000 



















Example: 



If register RL3 contains %B2 (10110010), the instruction 

RESB RL3, #1 
will leave the value %B0 (10110000) in RL3. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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RESFLG 

Reset Flag 



RESFLG flag 



flag: C, Z, S, P, V 



Operation: 



FLAGS (4:7) *- FLAGS (4:7) AND NOT instruction (4:7) 



Flags: 



Any combination of the C, Z, S, P or V flags are cleared to zero if the corresponding 
bits in the instruction are one. If the bit in the instruction corresponding to a flag is 
zero, the flag will not be affected. All other bits in the FLAGS register are 
unaffected. Note that the P and V flags are represented by the same bit. 

There may be one, two, three, or four operands in the assembly language statement, 
in any order. 

C: Cleared if specified, unaffected otherwise 
Z: Cleared if specified, unaffected otherwise 
S: Cleared if specified, unaffected otherwise 
P/V: Cleared if specified, unaffected otherwise 
D: Unaffected 
H: Unaffected 





Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




RESFLG flags 








7 












10 


001101 |C2SP/V| 001 1 






1 


001 101 |CZSP/V| 001 1 j 


7 

















Example: If the C, S, and V flags are set (1) and the Z flag is clear (0), the statement 

RESFLG C, V 
will leave the S flag set (1), and the C, Z, and V flags cleared (0). 
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RET 

Return 



RET cc 



Operation: 



Nonsegmented 
if cc is true then 
PC ^ @SP 
SP <i- SP + 2 



Segmented 
if cc is true then 
PC — @SP 
SP ^ SP + 4 



This instruction is used to return to a previously executed procedure at the end of a 
procedure entered by a CALL or CALR instruction. If the condition specified by 
"cc" is satisfied by the flags in the FCW, then the contents of the location addressed 
by the processor stack pointer are popped into the program counter (PC). The next 
instruction executed is that addressed by the new contents of the PC. See section 
6.6 for a list of condition codes. The stack pointer used is R15 in nonsegmented 
mode, or RR14 in segmented mode. If the condition is not satisfied, then the instruc- 
tion following the RET instruction is executed. If no condition is specified, the return 
is taken regardless of the flag settings. 



Flags: No flags affected 


Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles^ 


Instruction Format 


Cycles^ 




RET cc 




10/7 








10 


O11110|oOOo| cc 1 


10 011110 0000 cc 


13/7 











Example: In nonsegmented mode, if the program counter contains %2550, the stack pointer 

(R15) contains %3000, location %3000 contains %1004, and the Z flag is clear, then 
the instruction 

RET NZ 

will leave the value % 3002 in the stack pointer and the program counter will contain 
%1004 (the address of the next instruction to be executed). 



Note 1: The two values correspond to return taken and return not taken. 
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RL 

Rotate Left 



RL dst, src 
RLB 



dst: R 
src: IM 



Operation: Do src times: (src = 1 or 2) 

tmp -«- dst 
c ■<- tmp (msb) 
dst(O) ■*- tmp (msb) 
dst (n + 1) <- tmp (n) (for n = to msb 



1) 



Flags: 



Word: [7]- 



Byte: 0^ 



The contents of the destination operand are rotated left one bit position if the source 
operand is 1, or two bit positions if the source operand is 2. The most significant bit 
(msb) of the destination operand is moved to the bit position and also replaces the 
C flag. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 

C: Set if the last bit rotated from the most significant bit position was 1 ; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during rotation; cleared otherwise 
D: Unaffected 
H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntaxi 


Nonsegmented Mode 


Segmented Mode 


Instruction FormatZ 


Cycles3 


Instruction Formats 


Cycles3 


R: 


RL Rd, #n 
RLB Rbd, #n 








6/7 












10 


1 1 001 


w 


Rd 


00 


S 









10 


1 1001 


w 


Rd 


00 


S 







6/7 



















Example: 



If register RH5 contains %88 (10001000), the statement 

RLB RH5 
will leave the value %11 (00010001) in RH5 and the Carry flag will be set to one. 



Note 1: n = source operand. 

Note 2: s = for rotation by I bit; s = 1 for rotation by 2 bits. 

Note 3: The given execution times are for rotation by 1 and 2 bits respectively. 
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RLC 

Rotate Left through Carry 


Operation: 


RLC dst: R 
RLCB src: IM 

Do src times: (src = 1 or 2) 
tmp •«- c 
c -*- dst (msb) 

dst (n + 1) ■«- dst (n) (for n = msb- 
dst (0) ^ tmp 


1 to 0) 




15 







Word: 1 — c ■*— 


-^ 










7 






ayte: c *- 





The contents of the destination operand with the C flag are rotated left one bit posi- 
tion if the source operand is 1, or two bit positions if the source operand is 2. The 
most significant bit (msb) of the destination operand replaces the C flag and the 
previous value of the C flag is moved to the bit position of the destination during 
each rotation. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1. 



Flags: 



C: Set if the last bit rotated from the most significant bit position was 1; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during rotation; cleared otherwise 
D: Unaffected 
H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntaxi 


Nonsegmented Mode 


Segmented Mode 


Instruction Format^ 


Cycles3 


Instruction FormatZ 


CyclesS 




RLC Rd, #n 
RLCB Rbd, #n 
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R: 




1 


11001 w 


Rd 


10 


S 









1 


11001 w 


Rd 10 S 
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Example: 



If the Carry flag is clear ( = 0) and register RO contains %800F (1000000000001111), 
the statement 

RLC R0,#2 

will leave the value %003D (0000000000111101) in RO and clear the Carry flag. 



Note 1 
Note 2 
Note 3 



n = source operand. 

s = for rotation by 1 bit; s = 1 for rotation by 2 bits. 

The given execution times are for rotation by 1 and 2 bits respectively. 
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RLDB 

Rotate Left Digit 



RLDB link, src 



src: R 
link: R 



Operation: 



tmp (0:3) ■*- link (0:3) 
link (0:3) ^- src (4:7) 
src (4:7) ■*- src (0:3) 
src (0:3) ■*- tmp (0:3) 



Flags: 



link 



T 



I 



The low digit of the link byte register is logically concatenated to the source byte 
register. The resulting three-digit quantity is rotated to the left by one BCD digit 
(four bits). The lower digit of the source is moved to the upper digit of the source; 
the upper digit of the source is moved to the lower digit of the link, and the lower 
digit of the link is moved to the lower digit of the source. The upper digit of the link 
is unaffected. In multiple-digit BCD arithmetic, this instruction can be used to shift 
to the left a string of BCD digits, thus multiplying, it by a power of ten. The link 
serves to transfer digits between successive bytes of the string. This is analogous to 
the use of the Carry flag in multiple precision shifting using the RLC instruction. 

The same byte register must not be used as both the source and the link. 

C: Unaffected 

Z: Set if the link is zero after the operation; cleared otherwise 

S: Undefined 

V: Unaffected 

D: Unaffected 

H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




RLDBRbl, Rbs 








9 








R: 




10 111110 Rbs Rbl 






10 111110 Rbs Rbl 1 


9 
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Example: If location 100 contains the BCD digits 0,1 (00000001), location 101 contains 2,3 

(00100011), and location 102 contains 4,5 (01000101) 



100 



101 



102 



the sequence of statements 
LD 



R3,#3 



LOOP: 



!set loop counter for 3 bytes! 
!(6 digits)! 

!set pointer to low- order digits! 
!zero-fill low-order digit! 

!get next two digits! 

! shift digits left one position! 

! replace shifted digits! 

! advance pointer! 

! repeat until counter is zero! 

will leave the digits 1,2 (00010010) in location 100, the digits 3,4 (00110100) in loca- 
tion 101, and the digits 5,0 (01010000) in location 102. 



LD 


R2,#102 


CLRB 


RHl 


LDB 


RL1,@R2 


RLDB 


RH1,RL1 


LDB 


@R2,RL1 


DEC 


R2 


DJNZ 


R3, LOOP 



100 



101 



102 



In segmented mode, R2 would be replaced by a register pair. 
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RR 

Rotate Right 



RR dst, src 
RRB 



dst: R 
src: IM 



Operation: Do src times: (src = 1 or 2) 

tmp -^ dst 
c -^ tmp (0) 
dot (msb) ■*- tmp (0) 
dst (n - 1) -^ tmp (n) (for n = 1 to msb) 



Word: 



Byte: 



-B 



*0 



Flags: 



The contents of the destination operand are rotated right one bit position if the 
source operand is 1, or two bit positions if the source operand is 2. The least signifi- 
cant bit of the destination operand is moved to the most significant bit (msb) and 
also replaces the C flag. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 

C: Set if the last bit rotated from the least significant position was 1; cleared 

otherwise 
Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during rotation; cleared otherwise 
D: Unaffected 
H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Formatl 


Cycles^ 


Instruction Format! 


Cycles^ 




RR Rd, #n 
RRB Rbd, #n 
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R: 




10 


1 1001 


w 


Rd 


01 


S 









10 


11001 


w 


Rd 


01 


S 
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Example: 



If register RL6 contains %31 (00110001), the statement 

RRB RL6 
will leave the value %98 (10011000) in RL6 and the Carry flag will be set to one. 



Note 1: s = for rotation by 1 bit; s = 1 for rotation by 2 bits. 

Note 2: The given execution times are for rotation by 1 and 2 bits respectively. 
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RRC 

Rotate Right through Carry 



RRC dst, src 
RRCB 



dst: R 
src: IM 



Operation: Do src times: (src = 1 or 2) 

tmp -«- c 
c ■*- dst (0) 

dst (n) ^ dst (ri + 1) (for n 
dst (msb) -«- tmp 



to msb - 1) 



Flags: 



Word: 



Byte: 



'EH 



u 



-qJ 



The contents of the destination operand with the C flag are rotated one bit position if 
the source operand is 1, or two bit positions if the source operand is 2. The least 
significant bit of the destination operand replaces the C flag and the previous value 
of the C flag is moved to the most significant bit (msb) position of the destination 
during each rotation. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 

C: Set if the last bit rotated from the least significant bit position was 1; cleared 

otherwise 
Z: Sot if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during rotation; cleared otherwise 
D: Unaffected 
H: Unaffected 



Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format^ 



Cycles^ 



Segmented Mode 



Instruction Format^ 



Cycles^ 



RRC Rd, #n 
RRCB Rbd, #n 



ra 


1 1001 


w 


Rd 


1 1 


S 
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10 


11001 


w 


Rd 


1 1 


s 


3 
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Example: If the Carry flag is clear ( = 0) and the register RO contains %OODD 

(000000001 1011 101), the statement 

RRC R0,#2 

will leave the value %8037 (10000000110111) in RO and clear the Carry flag. 



Note 1 : s = for rotation by 1 bit; s = 1 for rotation by 2 bits 

Note 2: The given execution times are for rotation by 1 and 2 bits respectively. 



6-123 



RRDB 

Rotate Right Digit 



RRDB link, src 



src: R 
link: R 



Operation: 



tmp (0:3) ■<- link (0:3) 
link (0:3) ■*- src (0:3) 
src (0:3) ■*- src (4:7) 
src (4:7) ^- tmp (0:3) 



Flags: 



link 



i 



The low digit of the link byte register is logically concatenated to the source byte 
register. The resulting three-digit guantity is rotated to the right by one BCD digit 
(four bits). 

The lower digit of the source is riioved to the lower digit of the link; the upper digit 
of the source is moved to the lower digit of the source and the lower digit of the link 
is moved to the upper digit of the source. 

The upper digit of the link is unaffected. In multiple-digit BCD arithmetic, this 
instruction can be used to shift to the right a string of BCD digits, thus dividing it by 
a power of ten. The link serves to transfer digits between successive bytes of the 
string. This is analogous to the use of the carry flag in multiple precision shifting 
using the RRC instruction. 

The same byte register must not be used as both the source and the link. 

C: Unaffected 

Z: Set if the link is zero after the operation; cleared otherwise 

S: Undefined 

V: Unaffected 

D: Unaffected 

H: Unaffected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




RRDB Rbl, Rbs 




9 






R: 


10 111100 Rbs Rbl 


10[ 1 1 1 1 00 Rbs Rbl 


9 











6-124 



03-8003-0939 



Example: If location 100 contains the BCD digits 1,2 (00010010), location 101 contains 3,4 

(00110100), and location 102 contains 5,6 (01010110) 



100 



101 



102 



the sequence of statements 




LD 


R3,#3 


LD 


R2,100 


CLRB 


RHl 


LOOP: 




LDB 


RL1,@R2 


RRDB 


RH1,RL1 


LDB 


@R2,RL1 


INC 


R2 


DJNZ 


R3,LOOP 



!set loop counter for 3 bytes (6 
digits)! 

!set pointer to high-order digits! 
! zero- fill high-order digit! 

!get next two digits! 

! shift digits right one position! 

! replace shifted digits! 

! advance pointer! 

! repeat until counter is zero! 

will leave the digits 0,1 (00000001) in location 100, the digits 2,3 (00100011) in loca- 
tion 101, and the digits 4,5 (01000101) in location 102. RHl will contain 6, the 
remainder from dividing the string by 10. 



100 



101 



102 



In segmented mode, R2 would be replaced by a register pair. 
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SBC 

Subtract with Carry 



SBC dst, src 
SBCB 



dst: R 
src: R 



Operation: 



dst -*- dst - src - C 



Flags: 



The source operand, along with the setting of the carry flag, is subtracted from the 
destination operand and the result is stored in the destination. The contents of the 
source are not affected. Subtraction is performed by adding the two's complement of 
the source operand to the destination operand. In multiple precision arithmetic, this 
instruction permits the carry ("borrow") from the subtraction of low-order operands 
to be subtracted from the subtraction of high-order operands. 

C: Cleared if there is a carry from the most significant bit of the result; set 

otherwise, indicating a "borrow" 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the operands were of opposite signs 

and the sign of the result is the same as the sign of the source; cleared otherwise 
D: SBC— unaffected; SBCB— set 
H: SBC — unaffected; SBCB — cleared if there is a carry from the most significant bit 

of the low-order four bits of the result; set otherwise, indicating a "borrow" 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


SBC Rd, Rs 
SBCB Rbd, Rbs 








5 












10 


11011 


w 


Rs 


Rd 






10 


11011 


w 


Rs 


Rd 




5 



















Example: 



Long subtraction may be done with the following instruction sequence, assuming RO, 
RI contain one operand and R2, R3 contain the other operand: 

SUB R1,R3 Isubtract low-order words! 

SBC R0,R2 Isubtract carry and high-order words! 

If RO contains %0038, Rl contains %4000, R2 contains %000A and R3 contains 
%F000, then the above two instructions leave the value %002D in RO and %5000 
inRl. 
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Privileged Instruction 



SC 

System Call 



SCsrc 



src: IM 



Operation: 



Nonsegmented 
SP -- SP - 4 
@SP <i- PS 
SP -^ SP - 2 
@SP -*- instruction 
PS <i- System Call PS 



Segmented 
SP ^ SP - 6 
@SP -- PS 
SP ^ SP - 2 
@SP -•- instruction 
PS — System Call PS 



This instruction is used for controlled access to operating system software in a man- 
ner similar to a trap or interrupt. The current program status (PS) is pushed on the 
system processor stack, and then the instruction itself, which includes the source 
operand (an 8-bit value) is pushed. The PS includes the Flag and Control Word 
(FCW), and the updated program counter (PC). (The updated program counter 
value used is the address of the first instruction byte following the SC instruction.) 

The system stack pointer is always used (R15 in nonsegmented mode, or RR14 in 
segmented mode), regardless of whether system or normal mode is in effect. The 
new PS is then loaded from the Program Status block associated with the System 
Call trap (see section 6.2.4), and control is passed to the procedure whose address is 
the program counter value contained in the new PS. This procedure may inspect the 
source operand on the top of the stack to determine the particular software service 
desired. 

The following figure illustrates the format of the saved program status in the system 
stack: 



N 


ONSEGMENTE 


D 

LOW 
ADDRESS 

HIGH 
ADDRESS 


SP AFTER »- 

SP BEFORE ► 


SEGMENTED 


LOW 
ADDRESS 




IDENTIFIER 




AFTER TRAP - 


IDENTIFIER 


FCW 






FCW 


PC SEGMENT 






PC 


PC OFFSET 




BEFORE TRAP ^ 

OR INTERRUPT 








1*-^ WORD-* 


-^1 WORD-*- 


HIGH 
ADDRESS 



Flags: 



The Z8001 version always executes the segmented mode of the System Call instruc- 
tion, regardless of the current mode, and sets the Segmentation Mode bit (SEG) to 
segmented mode ( = 1) at the start of the SC instruction execution. Both the Z8001 
and Z8002 versions set the System/Normal Mode bit (S/N) to system mode ( = 1) at 
the start of the SC instruction execution. The status pins reflect the setting of these 
control bits during the execution of the SC instruction. However, the setting of SEG 
and S/N does not affect the value of these bits in the old FCW pushed onto the stack. 
The new value of the FCW is not effective until the next instruction, so that the status 
pins will not be affected by the new control bits until after the SC instruction execu- 
tion is completed. 

The "src field" in the instruction format encoding contains the source operand. The 
"src field" values range from to 255 corresponding to the source values to 255. 

No flags affected 

Flags loaded from Program Status Area 
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Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


' 


SC #src 




33 






IM: 


1111111 src 


1111111 src 


39 











Example: 



In the nonsegmented Z8002, if the contents of the program counter are %1000, the 
contents of the system stack pointer (R15) are °/o3006, and the Program Counter and 
FCW values associated with the System Call trap in the Program Status Area are 
%2000 and %1000, respectively, the instruction 

SC #3 ! system call, request code = 3! 

causes the system stack pointer to be decremented to %3000. Location %3000 con- 
tains %7F03 (the SC instruction). Location %3002 contains the old FCW, and loca- 
tion °/o3004 contains %1002 (the address of the instruction following the SC instruc- 
tion). System mode is in effect, and the Program Counter contains the value %2000, 
which is the start of a System Call trap handler, and the FCW contains °/olOOO. 
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SDA 

Shift Dynamic Arithmetic 



SDA dst, src 

SDAB 

SDAL 



dst: R 
src: R 



Operation: 



Right (src negative) 
Do src times: 

c ■*- dst (0) 

dst (n) -*- dst (n + 1) (for n = to msb 

dst (msb) '*- dst (msb) 
Left (src positive) 
Do src times: 

c ■*- dst (msb) 



1) 



dst (n + 
dst (0) ^ 



dst (n) (for n = msb - 1 to 0) 



Right 



Left 



Byte: 
Word: 
Long: 


r-*- 


— »- 


T 

15 







p^ 




— ►- 


15 







r-^ 


Rn 




1 








15 









L* 


Rn + 1 


»■ 



c c ■< — 


■^ 


15 





c c -• — 


■< — 


15 





c ■^— 


Rn •< 1 




15 





- c 1 


Rn+1 M 



n = 0,2,4,...,14 



n = 0,2,4,...,14 



Flags: 



The destination operand is shifted arithmetically left or right by the number of bit 
positions specified by the contents of the source operand, a word register. 

The shift count ranges from -8 to +8 for SDAB, from -16 to + 16 for SDA and from 
-32 to +32 for SDAL. If the value is outside the specified range, the operation is 
undefined. The source operand is represented as a 16-bit two's complement value. 
Positive values specify a left shift, while negative values specify a right shift. A shift 
of zero positions does not affect the destination; however, the flags are set according 
to the destination value. The sign bit is replicated in shifts to the right, and the C 
flag is loaded from bit of the destination. The least significant bit is filled with in 
shifts to the left, and the C flag is loaded from the most significant bit (msb) of the 
destination. The setting of the carry bit is undefined for zero shift. 

C: Set if the last bit shifted from the destination was 1 , undefined for zero shift; 

cleared otherwise 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during shifting; cleared otherwise 
D: Unaffected 
H: Unaffected 
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Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles' 



Segmented Mode 



Instruction Format 



Cycles' 



R: 



SDA Rd, Rs 



SDAB Rbd, Rs 



SDAL RRd, Rs 



10 


110011 


Rd 


1011 


0000 


Rs 


0000 0000 




10 


110010 


Rd 


1011 


0000 


Rs 


0000 0000 1 




10 


110011 


Rd 


1111 


0000 


Rs 


0000 0000 



15 + 3n 



15 + 3n 



15 + 3n 



10 


110011 


Rd 


1011 


0000 


Rs 


0000 0000 




1 


1 10010 


Rd 


1011 


0000 


Rs 


0000 0000 




10 


110011 


Rd 


1111 


0000 


Rs 


0000 0000 



15 + 3n 



15 + 3n 



15 + 3n 



Example: If register R5 contains %C705 (1100011100000101) and register Rl contains -2 

(%FFFE or 1111111111111110), the statement 

SDA R5,R1 

performs an arithmetic right shift of two bit positions, leaves the value %F1C1 
(111 10001 1 1000001) in R5, and clears the Carry flag. 

Note 1 : n = number of bit positions; the execution time for n = is the same as for n = 1 . 
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SDL 

Shift Dynamic Logical 



SDL dst, src 

SDLB 

SDLL 



dst: R 
src: R 



-Operation: Right 

Do src times 
c ■*- dst (0) 

dst (n) M- dst (n + 1) (for n = to msb - 1) 
dst (msb) ■*- 

Left 

Do src times 

c -*- dst (msb) 

dst (n + 1) ^ dst (n) (for n = msb - 1 to 0) 

dst (0) ^ 



Right 



Left 



Flags: 



Byte: o— ^ 




— »- 




5 


C 




Word: o— ^ 




— »- 




5 







Long: o — •- 


Rn 
















5 









— *- 


Rn + 1 


— »- 



- c c -* 


-• 


15 





C C -« -« 


15 





C -« 


^n 




15 





c 1 


Rn + 1 M 



n = 0,2,4 14 



n = 0,2,4 14 



The destination operand is shifted logically left or right by the number of bit posi- 
tions specified by the contents of the source operand, a word register. The shift 
count ranges from -8 to +8 for SDL, from -16 to + 16 for SDLB and from -32 to 
4-32 for SDLL. If the value is outside the specified range, the operation is 
undefined. The source operand is represented as a 16-bit two's complement value. 
Positive values specify a left shift, while negative values specify a right shift. A shift 
of zero positions does not affect the destination; however, the flags are set according 
to the destination value. The most significant bit (msb) is filled with in shifts to the 
right, and the C flag is loaded from bit of the destination. The least significant bit 
is filled with in shifts to the left, and the C flag is loaded from the most significant 
bit of the destination. The setting of the carry bit is undefined for zero shift. 

C: Set if the last bit shifted from the destination was 1 , undefined for zero shift; 

cleared otherwise 
Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 
V: Undefined 
D: Unaffected 
H: Unaffected 
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Destination 

Addressing 

Mode 



Assembler Longuage 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



SDL Rd, Rs 



SDLB Rbd, Rs 



SDLL RRd, Rs 



1 


110011 


Rd 


001 1 


0000 


Rs 


0000 0000 




10 


110010 


Rd 


001 l| 


0000 


Rs 


0000 0000 




1 


110011 


Rd 


0111 


0000 


Rs 


0000 0000 



15 + 3n 



15 + 3n 



15 + 3n 



1 


110011 


Rd 


001 1 


0000 


Rs 


0000 0000 




1 


110010 


Rd 


001 l| 


0000 


Rs 


0000 0000 1 




1 


110 11 


Rd 


01 11 


0000 


Rs 


0000 0000 



15 + 3n 



15 + 3n 



15 + 3n 



Example: If register RL5 contains %B3 (10110011) and register Rl contains 4 

(0000000000000100), the statement 

SDLB RL5,Rr 

performs a logical left shift of four bit positions, leaves the value %30 (00110000) in 
RL5, and sets the Carry flag. 



Note 1 : n = number of bit positions; the execution time for n = is the same as for n = 1 . 
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SET 

Set Bit 



SET dst, src 
SETB 



dst: R, IR, DA, X 

src: IM 

or 

dst: R 

src: R 



Operation: 



dst(src) 



1 



Sets the specified bit within the destination operand without affecting any other bits 
in the destination. The source (the bit number) can be specified as either an immedi- 
ate value (Static), or as a word register which contains the value (Dynamic). In the 
second case, the destination operand must be a register, and the source operand 
must be RO through R7 for SETB, or RO through R15 for SET. The bit number is a 
value from to 7 for SETB or to 15 for SET, with indicating the least significant 
bit. 

Only the lower four bits of the source operand are used to specify the bit number for 
SET, while only the lower three bits of the source operand are used with SETB. 
When the source operand is an immediate value, the "src field" in the instruction 
format encoding contains the bit number in the lowest four bits for SET, or the 
lowest three bits for SETB. 



Flags: 



No flags affected 



Set Bit Static 
































Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


SET Rd, #b 
SETB Rbd, §h 

SET @Rdi , #b 
SETB@Rdi, #b 

SET address, #b 
SETB address, #b 

SET addr(Rd), #b 
SETB addr(Rd), #b 








4 
11 

13 
14 










1 


10010 


W 


Rd 


b 






10 


10010 


W 


Rd 


b 


4 


IR: 
















00 


10010 


W 


Rd?^0 


b 






00 


10010 


W 


Rd:itO 


b 


11 


DA: 
















01 


10010 


W 


0000 


b 




SS 


01 


10010 


W 


0000 


b 


14 




address 





segment 


offset 




















SL 


01 


10010 


« 


0000 


b 






1 


segment 


0000 0000 1 


16 




offset 




X: 
















01 


10010 


W 


Rd^O 


b 




88 


01 


10010 


w 


M*0 


b 


14 




address 





segment 


offset 




















8L 


01 


10010 


w 


Rd:^0 


- 






1 


segment 


0000 0000 


17 




offset 


















_ 
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Set Bit Dynamic 






















Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




SET Rd, Rs 
SETB Rbd, Rs 








10 










R: 




00 1 001 w 


Rs 






00 1 001 w 


Rs 




10 




Rd 


0000 0000 


Rd 


0000 0000 



















Example: 



If register RL3 contains %B2 (10110010) and register R2 contains the value 6, the 
instruction 

SETB RL3, R2 

will leave the value %F2 (11110010) in RL3. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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SETFLG 

Set Flag 



SETFLG flag 



Flag: C, Z, S, P, V 



Operation: FLAGS (4:7) ■*- FLAGS (4:7) OR instruction (4:7) 

Any combination of the C, Z, S, P or V flags are set to one if the corresponding bits 
in the instruction are one. If the bit in the instruction corresponding to a flag is zero, 
the flag will not be affected. All other bits in the FLAGS register are unaffected. 
Note that the P and V flags are represented by the same bit. 

There may be one, two, three, or four operands in the assembly language statement, 
in any order. 



Flags: 



C: Set if specified; unaffected otherwise 
Z: Set if specified; unaffected otherwise 
S: Set if specified; unaffected otherwise 
P/V: Set if specified; unaffected otherwise 
D: Unaffected 
H: Unaffected 





Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 




Instruction Format 


Cycles 


Instruction Format 


Cycles 




SETFLG flags 






7 














10001 101 


CZSP/V 


0001 1 




1 0001 1 01 


CZSP/V 


0001 




7 

















Example: If the C, Z, and S flags are all clear (0), and the P flag is set (1), the statement 

SETFLG C 
will leave the C and P flags set (1), and the Z and S flags cleared (0). 
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SLA 

Shift Left Arithmetic 



SLA dst, src 

SLAB 

SLAL 



dst: R 
src: IM 



Operation: Do src times: 

c ■<- dst (msb) 

dst (n + 1) -•- dst (n) (for n = msb - 1 to 0) 

dst (0) ^0 



Byte: |T|- 



Word: 


c - 

c - 


* — 




■< 




15 







Long: 


* 


Rn 


-< 














15 













Rn + 1 


-« — 



n = 0, 2, 4, ..., 14 

The destination operand is shifted arithmetically left the number of bit positions 
specified by the source operand. For SLAB, the source is in the range to 8; for 
SLA, the source is in the range to 16; for SLAL, the source is in the range to 32. 
A shift of zero positions does not affect the destination; however, the flags are set 
according to the destination value. The least significant bit of the destination is filled 
with 0, and the C flag is loaded from the sign bit of the destination. The operation is 
the equivalent of a multiplication of the destination by a power of two with overflow 
indication. 

The src field is encoded in the instruction format as the 8- or 16-bit two's comple- 
ment positive value of the source operand. For each operand size, the operation is 
undefined if the source operand is not in the specified range. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 



Flags: 



C: Set if the last bit shifted from the destination was 1 , undefined for zero shift; 

cleared otherwise 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the sign of the destination changed 

during shifting; cleared otherwise 
D: Unaffected 
H: Unaffected 
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03-8003-0943 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles^ 


Instruction Format 


Cycles* 


R: 


SLA Rd, #b 
SLAB Rbd, #b 
SLAL RRd, #b 








13 + 3b 
13 + 3b 
13 + 3b 












10 


110011 


Rd 


1001 






10 


110011 


Rd 


1001 




13 + 3b 




b 


b 
























1 


110010 


Rd 


1001 






10 


1 10010 


Rd 


1001 




13 + 3b 







b 





b 
























10, 


110011 


Rd 


1 101 






10 


1 10011 


Rd 


1101 




13 + 3b 




b 


b 





















Example: If register pair RR2 contains %1234ABCD, the statement 

SLAL RR2,#8 
will leave the value %34ABCD00 in RR2 and clear the Carry flag. 

Note 1: b = number of bit positions; the execution time for b = is the same as for b = 1. 
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SLL 

Shift Left Logical 



SLL dst, src 

SLB 

SLLL 



dst: R 
src: IM 



Operation: 



Do src times: 

c -*- dst (msb) 
dst (n + 1) -.- 
dst (0) *- 



dst (n) (for n = msb - 1 to 0) 



Flags: 



Byte: IT]- 
Word: 0- 



Long: | ^ r 



* — 




■^ 




15 











Rn 




* 
















15 




C 






Rn + 1 






* 



n = 0, 2, 4, ..., 14 

The destination operand is shifted logically left by the number of bit positions 
specified by the source operand. For SLLB, the source is in the range to 8; for 
SLL, the source is in the range to 16; for SLLL, the source is in the range to 32. 
A shift of zero positions does not affect the destination; however, the flags are set 
according to the destination value. The setting of the carry bit is undefined for zero 
shift. The least significant bit of the destination is filled with 0, and the C flag is 
loaded from the most significant bit (msb) of the destination. This instruction per- 
forms an unsigned multiplication of the destination by a power of two. 

The src field is encoded in the instruction format as the 8- or 16-bit positive value of 
the source operand. For each operand size, the operation is undefined if the source 
operand is not in the specified range. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 

C: Set if the last bit shifted from the destination was 1 , undefined for zero shift; 

cleared otherwise 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

V: Undefined 

D: Unaffected 

H: Unaffected 
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Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles! 


Instruction Format 


Cycles! 


R: 


SLL Rd, #b 
SLLB Rbd, #b 
SLLL RRd, #b 








13 + 3b 
13 + 3b 
13 + 3b 












10 


110011 


Rd 


0001 






10 


110011 


Rd 


0001 




13 + 3b 




b 


b 
























10 


110010 


Rd 


0001 






10 1 10010 


Rd 


0001 




13 + 3b 







b 





b 
























10 


1 1001 1 


Rd 


0101 






10 


110011 


Rd 


0101 




13 + 3b 




b 


b 





















Example: 



If register R3 contains %4321 (0100001 100100001), the statement 

SLL R3,#l 
will leave the value %8642 (1000011001000010) in R3 and clear the carry flag. 



Note 1 : b = number of bit positions; the execution time for b =0 is the same as for b = 1 . 
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SRA 

Shift Right Arithmetic 



SRA dst, src 

SRAB 

SEAL 



dst: R 
src: IM 



Operation: Do src times: 

c ^ dst (0) 

dst (n) ■*- dst (n + l)(for n = to msb - 1) 

dst (msb) -*- dst (msb) 



Flags: 



Byte: 



Word: 



Q 



Q 

Long: r-^ 



■B 



-m 



n = 0, 2, 4 14 



The destination operand is shifted arithmetically right by the number of bit positions 
specified by the source operands. For SRAB, the source is in the range to 8; for 
SRA, the source is in the range to 16; for SRAL, the source is in the range to 32. 
A right shift of zero for SRA is not possible. The most significant bit (msb) of the 
destination is replicated, and the C flag is loaded from bit of the destination, this 
instruction performs a signed division of the destination by a power of two. 

The src field is encoded in the instruction format as the 8- or 16-bit two's comple- 
ment negative of the source operand. For each operand size, the operation is 
undefined if the source operand is not in the specified range. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value 1 . 

C: Set if the last bit shifted from the destination was 1; cleared otherwise 

Z: Set if the result is zero; cleared otherwise 

S: Set if the result is negative; cleared otherwise 

V: Cleared 

D: Unaffected 

H: Unaffected 
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Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles^ 


Instruction Format 


Cycles^ 




SRA Rd, #b 
SRAB Rbd, #b 
SRAL RRd, #b 








13 + 3b 
13 + 3b 
13 + 3b 










R: 




10 


110011 


Rd 


1 001 






1 


110011 


Rd 


1 001 




13 + 3b 




-b 


-b 






















10 


110010 


Rd 


1 001 






1 


110010 


Rd 


1001 




13 + 3b 







-b 


° 


-b 






















10 


110011 


Rd 


1 1 01 






1 


110011 


Rd 


1101 




13 + 3b 




-b 


-b 





















Example: 



If register RH6 contains %3B (00111011), the statement 

SRAB RH6,#2 
will leave the value %0E (00001110) in RH6 and set the carry flag. 



Note 1 : b = number of bit positions; the execution time for b = is the same as for b = 1 . 
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SRL 

Shift Right Logical 



SRL dst, src 

SRLB 

SELL 



dst: R 
src: IM 



Operation: Do src times: 

c ^ dst (0) 

dst (n) <- dst (n + l)(for n = to msb - 1) 

dst (msb) ■<- 



Byte: 



Flags: 



Word: o 


-^ 




— » 






15 









Long: ° 


-► 


Rn 




















15 











— »■ 


Rn + 1 


— »> 



HI] 
El 



■Q 



n = 0, 2, 4, ..., 14 



The destination operand is shifted logically right by the number of bit positions 
specified by the source operand. For SRLB, the source operand is in the range to 
8; for SRL, the source is in the range to 16; for SRLL, the source is in the range 
to 32. A right shift of zero for SRL is not possible. The most significant bit (msb) of 
the destination is filled with 0, and the C flag is loaded from bit of the destination. 
This instruction performs an unsigned division of the destination by a power of two. 

The src field is encoded in the instruction format as the 8- or 16-bit negative value of 
the source operand in two's complement rotation. For each operand size, the opera- 
tion is undefined if the source operand is not in the range specified above. 

The source operand may be omitted from the assembly language statement and thus 
defaults to the value of 1 . 

C: Set if the last bit shifted from the destination was 1 ; cleared otherwise 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is one; cleared otherwise 

V: Undefined 

D: Unaffected 

H: Unaffected 
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Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles' 



Segmented Mode 



Instruction Format 



Cycles' 



R: 



SRL Rd, #b 



SRLB Rbd, #b 



SRLL RRd, 



10 110011 Rd 0001 



-b 



1 


1 1 0010 


Rd 


0001 





-b 



10 110011 Rd 0101 



13 + 3b 



13 + 3b 



13 + 3b 



1 


110011 


Rd 


0001 


-b 




1 


110010 


Rd 


0001 





- 


b 




10 


110011 


Rd 


0101 


-b 



13 + 3b 



13 + 3b 



13 + 3b 



Example: If register RO contains %1 1 1 1 (0001000100010001), the statement 

SRL R0,#6 
will leave the value %0044 (0000000001000100) in RO and clear the carry flag. 

Note 1: b = number of bit positions; the execution time for b = is the same as for b = 1. 
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SUB 

Subtract 



SUB dst, src 

SUBB 

SUBL 



dst: R 

src: R, IM, IR, DA, X 



Operation: 



dst ■*- dst - src 



Flags: 



The source operand is subtracted from the destination operand and the result is 
stored in the destination. The contents of the source are not affected. Subtraction is 
performed by adding the two's complement of the source operand to the destination 
operand. 

C: Cleared if there is a carry from the most significant bit; set otherwise, indicating 

a "borrow" 
Z: Set if the result is zero; cleared otherwise 
S: Set if the result is negative; cleared otherwise 
V: Set if arithmetic overflow occurs, that is, if the operands were of opposite signs 

and the sign of the result is the same as the sign of the source; cleared otherwise 
D: SUB, SUBL— unaffected; SUBB— set 
H: SUB, SUBL — unaffected; SUBB — cleared if there is a carry from the most 

significant bit of the low-order four bits of the result; set otherwise, indicating a 

"borrow" 



Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


SUB Rd, Rs 
SUBB Rbd, Rbs 

SUBL RRd, RRs 
SUB Rd, #data 

SUBB Rbd, #data 

SUBL RRd, #data 

SUB Rd, @Rsl 
SUBB Rbd, @Rsi 

SUBL RRd, @Rsi 








4 
8 

7 
7 

14 

7 
14 












1 


00001 


w 


Rs 


Rd 






10 


00001 


w 


Rs 


Rd 




4 






















1 01001 


RRs 


RRd 






1 


010010 


RRs 


RRd 




8 


IM: 


















00 


00001 


0000 


Rd 






00 


000010 


0000 


Rd 




7 




data 


data 






















00 


000011 


1 Rd 






00 00001 1 


0000 


Rd 




7 




data 


data 


data 


data 






















00 


010010 


0000 


Rd 






00 


010010 


0000 


Rd 








31 data (high) 16 


31 data (high) 16 


14 




15 data (low) o 


15 data (low) o 




IR: 


















00 


00001 


w 


Rs*0 


Rd 






00 


00001 


w 


RS:itO 


Rd 




7 






















00 


010010 


Rs*0 


Rd 






00 


010010 


RS:^0 


Rd 




14 
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Source 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


DA: 


SUB Rd, address 
SUBB Rbd, address 

SUBL RRd, address 

SUB Rd, addr(Rs) 
SUBB Rbd, addr(Rs) 

SUBL RRD, addr(Rs) 








9 
15 

10 
16 










01 


00001 


w 


0000 


Rd 




88 


01 


00001 


w 


0000 


Rd 1 


10 




address 





segment 


offset 




















8L 


01 


00001 


W 


0000 


Rd 






1 segment 


0000 0000 1 


12 




offset 






















01 


010010 


0000 


Rd 




88 


01 


010010 


00 00 Rd 


16 




address 





segment 


offset 




















8L 


01 


010010 


0000 


Rd 1 






1 


segment 


0000 0000 1 


18 




offset 


















X: 




01 


00001 


w 


Rs^O 


Rd 




88 


01 


00001 


W 


Rs*0 


Rd 


10 




address 





segment 


offset 1 




















8L 


01 


00001 


w 


Rs^O 


Rd 






1 segment 


0000 0000 1 


13 




offset 






















01 


010010 


Rs?iO 


Rd 




88 


01 


010010 


Rs*0 


Rd 


16 




address 





segment 


offset 1 






















8L 


01 


010010 


Rs*0 


Rd 






1 


segment 


0000 0000 1 


19 




offset 



























Example: 



If register RO contains %0344, the statement 

SUB RO,#%AA 
will leave the value %029A in RO. 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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TCC 

Test Condition Code 



TCC cc, dst 
TCCB 



dst: R 



Operation: 



if cc is satisfied then 
dst (0) ^ 1 



Flags: 



This instruction is used to create a Boolean data value based on the flags set by a 
previous operation. The flags in the FCW are tested to see if the condition specified 
by "cc" is satisfied. If the condition is satisfied, then the least significant bit of the 
destination is set. If the condition is not satisfied, bit zero of the destination is not 
cleared but retains its previous value. All other bits in the destination are unaffected 
by this instruction. 

No flags affected 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


TCC cc, Rd 
TCCB cc, Rbd 








5 












1 


10111 


w 


Rd 


cc 






10 


10111 


w 


Rd 


cc 




5 



















Example: 



If register Rl contains 0, and the Z flag is set, the statement 

TCC EQ,R1 
will leave the value 1 in Rl. 
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TEST 

Test 



TEST dst 

TESTE 

TESTL 



dst: R, IR, DA, X 



Operation: 



dst OR 



The destination operand is tested (logically OR ed with zero), and the Z, S and P 
flags are set to reflect the attributes of the result. The flags may then be used for 
logical conditional jumps. The contents of the destination are not affected. 



Flags: 



C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; 

P: TEST— unaffected; TESTL— undefined; TESTB- 

cleared otherwise 
D: Unaffected 
H: Unaffected 



cleared otherwise 

-set if parity of the result is even; 



Destination 

Addressing 

Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


TEST Rd 
TESTE Rbd 

TESTL RRd 

TEST @Rdi 
TESTE @Rdi 

TESTL @Rdi 

TEST address 
TESTE address 

TESTL address 








7 
13 

8 
13 

11 
16 










1 


00110 


W 


Rd 


0100 






1 


001 10 


W 


Rd 


01 00 


7 




















1 


011100 


Rd 


1000 






10 


011100 


Rd 


1000 


13 
















IR: 




00 


001 10 


W 


Rd :!t 


0100 






00 


001 10 


W 


Rd*0 


0100 


8 


















00 


011100 


Rd^O 


1000 






00 


011100 


Rd:^0 


1000 


13 














DA: 




01 


00110 


W 


0000 


0100 




SS 


01 


001 10 


W 


0000 


0100 


12 




address 





segment 


offset 1 




















SL 


01 


001 10 


W 


0000 


01 00 






1 segment 


0000 0000 1 


14 




address 






















01 


011100 


0000 


1000 




38 


01 


011100 


0000 


1 000 1 


17 




address 


o| 


segment 


offset 






















SL 


01 


011100 


0000 


1000 






1 


segment 


0000 0000 


19 




offset 1 
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Destination 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



X: 



TEST addr(Rd) 
TESTE addr(Rd) 



01 001 10 W Rd^O 0100 



address 



12 



01 011100 Rd?!=0 1O0 



address 



17 





01 


01 10 


W 


Rd^O 


0100 


oo 


"I 


segment 


offset 








01 


00110 


W 


Rd:>tO 


0100 


SL 


1 segment 


0000 0000 1 




offset 






as 


01 


011100 


Rd^O 


1000 1 





segment 


offset 








01 


011100 


Rd?^0 


1000 


SL 


1 


segment 


0000 0000 




offset 



12 



15 



17 



20 



Example: If register R5 contains % FFFF (1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ), the statement 

TEST R5 
will set the S flag, clear the Z flag, and leave the other flags unaffected. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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TRDB 

Translate and Decrement 



Flags: 



dst: IR 
src: IR 



TRDB dst, src, r 

Operation: dst -*- src [dst] 

AUTODECREMENT dst by 1 
r -^ r - 1 

This instruction is used to translate a string of bytes from one code to another code. 
The contents of the location addressed by the destination register (the "target byte") 
are used as an index into a table of translation values whose lowest address is con- 
tained in the source register. The index is computed by adding the target byte to the 
address contained in the source register. The addition is performed following the 
rule for address arithmetic, with the target byte treated as an unsigned 8-bit value 
extended with high-order zeros. The sum is used as the address of an 8-bit transla- 
tion value within the table which replaces the original contents of the location 
addressed by the destination register. 

The destination register is then decremented by one, thus moving the pointer to the 
previous element in the string. The word register specified by "r" (used as a 
counter) is then decremented by one. The original contents of register RHl are lost 
and are replaced by an undefined value. Rl in nonsegmented mode, or RRO in 
segmented mode, must not be used as a source or destination pointer, and Rl should 
not be used as a counter. The source, destination, and counter registers must be 
separate and non- overlapping registers. 

Because the 8-bit target byte is added to the source register to obtain the address of 
a translation value, the table may contain 256 bytes. A smaller table size may be 
used where it is known that not all possible 8-bit target byte values will occur. The 
source register is unchanged. 



C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 




TRDB @Rdl, @Rsl, r 








25 










IR: 




10 


1 1 1000 


Rd # 


1000 






1 


1 1 1 000 


Rd ^0 


1 000 




2'; 




0000 


r 


Rs :^ 


0000 


0000 


r 


RS :!t 


0000 





















Example: 



In nonsegmented mode, if register R6 contains %4001, the byte at location %4001 
contains 3, register R9 contains %1000, the byte at location °/ol003 contains %AA, 
and register R12 contains 2, the instruction 

TRDB @R6, @R9, R12 

will leave the value %AA in location °/o4001, the value %4000 in R6, and the value 
1 in R12. R9 will not be affected. The V flag will be cleared. RHl will be set to an 
undefined value. In segmented mode, R6 and R9 would be replaced with 
register pairs. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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TRDRB 

Translate, Decrement and Repeat 



TRDRB dst, src, R 



dst: IR 
src: IR 



Operation: dst ♦- src [dst] 

AUTODECREMENT dst by 1 

T M- T — 1 

repeat until r = 



Flags: 



This instruction is used to translate a string of bytes from one code to another code. 
The contents of the location addressed by the destination register (the "target byte") 
are used as an index into a table of translation values whose lowest address is con- 
tained in the source register. The index is computed by adding the target byte to the 
address contained in the source register. The addition is performed following the 
rules for address arithmetic, with the target byte treated as an unsigned 8-bit value 
extended with high-order zeros. The sum is used as the address of an 8-bit transla- 
tion value within the table that replaces the original contents of the location 
addressed by the destination register. 

The destination register is then decremented by one, thus moving the pointer to the 
previous element in the string. The word register specified by "r" (used as a 
counter) is then decremented by one. The entire operation is repeated until the 
result of decrementing r is zero. This instruction can translate from 1 to 65536 bytes. 
The original contents of register RHl are lost and are replaced by an undefined 
value. The source register is unchanged. The source, destination, and counter 
registers must be separate and non-overlapping registers. 

Because the 8-bit target byte is added to the source register to obtain the address of 
a translation value, the table may contain 256 bytes. A smaller table size may be 
used where it is known that not all possible 8-bit target byte values will occur. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter of the start of this instruction is saved before the interrupt request 
is accepted, so the instruction can be properly resumed. Seven cycles should be 
added to this instruction's execution time for each interrupt request that is accepted. 

C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles^ 



Segmented Mode 



Instruction Format 



Cycles^ 



IR: 



TRDRB @Rbdl , @Rbsl , r 



10 


1 1 1 000 


Rd*0 


1 100 


0000 


r 


Rs TtO 


0000 



11+14n 



10 


1 1 1000 


Rd^O 


1100 


000 


r 


Rs ^0 


0000 



11 + 14n 
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Example: In nonsegmented mode, if register R6 contains %4002, the bytes at locations %4000 

through %4002 contain the values %00, %40, "MjSO, respectively, register R9 con- 
tains %1000, the translation table from location %1000 through %10FF contains 0, 
1,2, ..., %7F, 0, 1,2, ..., %7F (the second zero is located at %1080), and register 
R12 contains 3, the instruction 

TRDRB @R6, @R9, R12 

will leave the values %00, %40, %00 in byte locations %4000 through %4002, 
respectively. Register R6 will contain %3FFF, and R12 will contain 0. R9 will not be 
affected. The V flag will be set, and the contents of RHl will be replaced by an 
undefined value. In segmented mode, R6 and R9 would be replaced by register 
pairs. 



%4000 


00000000 


%4001 


10 


%4002 


10 




AFTER 


%4000 


00000000 


%4001 


10 


7o4002 


00000000 



7o1000 


00000000 


%1001 


1 


%1002 


10 


• 
• 
• 


• 


%107F 


1111111 


%1080 


00000000 


%1081 


1 


%1082 


10 


• 


• 


%10FF 


1111111 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements translated. 
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TRIB 

Translate and Increment 



TRIB dst, src, R 



dst: IR 
src: IR 



Operation: dst -*- src[dst] 

AUTOINCREMENT dst by 1 
r -*- r - 1 



Flags: 



This instruction is used to translate a string of bytes from one code to another code. 
The contents of the location addressed by the destination register (the "target byte") 
are used as an index into a table of translation values whose lowest address is con- 
tained in the source register. The index is computed by adding the target byte to the 
address contained in the source register. The addition is performed following the 
rules for address arithmetic, with the target byte treated as an unsigned 8-bit value 
extended with high-order zeros. The sum is used as the address of an 8-bit transla- 
tion value within the table which replaces the original contents of the location 
addressed by the destination register. The destination register is then incremented 
by one, thus moving the pointer to the next element in the string. The word register 
specified by "r" (used as a counter) is then decremented by one. The original con- 
tents of register RHl are lost and are replaced by an undefined value. The source 
register is unchanged. The source, destination, arid counter registers must be 
separate and non-overlapping registers. 

Because the 8-bit target byte is added to the source register to obtain the address of 
a translation value, the table may contain 256 bytes. A smaller table size may be 
used where it is known that not all possible 8-bit target byte values will occur. 

C: Unaffected 

Z: Undefined 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



TRIB @Rdi, @Rsl, r 



10 111 000 


Rd :><: 


0000 


0000 


r 


Rs ^ 


0000 



25 



10 


111000 


Rd ^0 


0000 


0000 


r 


Rs #0 


0000 



25 
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Example: 



This instruction can be used in a "loop" of instructions which translate a string of 
data from one code to any other desired code, but an intermediate operation on 
each data element is required. The following sequence translates a string of 1000 
bytes to the same string of bytes, with all ASCII "control characters" (values less 
than 32, see Appendix C) translated to the "blank" character (value = 32). A test, 
however, is made for the special character "return" (value = 13) which terminates 
the loop. The translation table contains 256 bytes. The first 33 (0-32) entries all con- 
tain the value 32, and all other entries contain their own index in the table, counting 
from zero. This example assumes nonsegmented mode. In segmented mode, R4 and 
R5 would be replaced by register pairs. 



LOOP: 



DONE: 



LD 

LDA 

LDA 

CPB 
JR 

TRIE 
JR 


R3, 
R4, 
R5, 

@R. 

EC 
@R. 

NO 

TABLE + 
TABLE +1 
TABLE + 2 

• 

TABLE + 32 
TABLE + 33 
TABLE + 34 

• 

• 

• 
TABLE + 255 


#1000 

STRING 

TABLE 

i, #13 

DONE 
i, @R5, R3 
V, LOOP 


! initialize counter! 
!load start addresses! 

! check for return character 

!exit loop if found! 

! translate next byte! 

! repeat until counter = 0! 




10 






10 






10 






• 
• 






10 






10 1 






10 10 






• 






11111111 





Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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TRIRB 

Translate, Increment and Repeat 



TRIRB dst, src, R 



dst: IR 
src: IR 



Operation: dst -*- src[dst] 

AUTOINCREMENT dst by 1 
r ■*- r - 1 
repeat until r = 

This instruction is used to translate a string of bytes from one code to another code. 
The contents of the location addressed by the destination register (the "target byte") 
are used as an index into a table of translation values whose lowest address is con- 
tained in the source register. The index is computed by adding the target byte to the 
address contained in the source register. The addition is performed following the 
rules for address arithmetic, with the target byte treated as an unsigned 8-bit value 
extended with high-order zeros. The sum is used as the address of an 8-bit transla- 
tion value within the table which replaces the original contents of the location 
addressed by the destination register. The destination register is then incremented 
by one, thus moving the pointer to the next element in the string. The word register 
specified by "r" (used as a counter) is then decremented by one. The entire opera- 
tion is repeated until the result of decrementing r is zero. This instruction can 
translate from 1 to 65536 bytes. The original contents of register RHl are lost and are 
replaced by an undefined value. The source register is unaffected. The source, 
destination, and counter registers must be separate and non- overlapping registers. 

Because the 8-bit target byte is added to the source register to obtain the address of 
a translation value, the table may contain 256 bytes. A smaller table size may be 
used where it is known that not all possible 8-bit target byte values will occur. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter of the start of this instruction is saved before the interrupt request 
is accepted, so that the instruction can be properly resumed. Seven cycles should be 
added to this instruction's execution time for each interrupt request that is accepted. 



Flags: 



C: Unaffected 
Z: Undefined 
S: Unaffected 
V: Set 

D: Unaffected 
H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles^ 


Instruction Format 


Cycles2 




TRIRB @Rdl , @Rsl , r 








11 + 14n 










IR: 




10 


1 1 1000 


Rd^O 


0100 






10 


1 1 1000 


Rd ^0 


0100 








0000 


r 


Rs ?t 


0000 


0000 


r 


Rs=i^O 


0000 


11 + 14n 



















6-154 



Example: The following sequence of instructions can be used to translate a string of 80 bytes 

from one code to another. The pointers to the string and the translation table are set, 
the number of bytes to translate is set, and then the translation is accomplished. 
After executing the last instruction, the V flag is set and the contents of RHl are lost. 
The example assumes nonsegmented mode. In segmented mode, R4 and R5 would 
be replaced by register pairs. 

LDA R4, STRING 

LDA R5, TABLE 

LD R3, #80 

TRIRB @R4, @R5, R3 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements translated. 
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TRTDB 

Translate, Test and Decrement 



TRTDB srcl, src2, R 



src 1: IR 
src 2: IR 



Operation: RHl ■*- src2[srcl] 

AUTODECREMENT srcl by 1 
r -<- r - 1 



Flags: 



This instruction is used to scan a string of bytes testing for bytes with special 
meaning. The contents of the location addressed by the first source register (the 
"target byte") are used as an index into a table of translation values whose lowest 
address is contained in the second source register. The index is computed by adding 
the target byte to the address contained in the second source register. The addition 
is performed following the rules for address arithmetic, with the target byte treated 
as an unsigned 8-bit value extended with high-order zeros. The sum is used as the 
address of an 8-bit value within the table which is loaded into register RHl. The Z 
flag is set if the value loaded into RHl is zero; otherwise the Z flag is cleared. The 
contents of the locations addressed by the source registers are not affected. The first 
source register is then decremented by one, thus moving the pointer to the previous 
element in the string. The word register specified by "r" (used as a counter) is then 
decremented by one. The second source register is unaffected. The source, destina- 
tion, and counter registers must be separate and non-overlapping registers. 

Because the 8-bit target byte is added to the second source register to obtain the 
address of a translation value, the table may contain 256 bytes. A smaller table size 
may be used where it is known that not all possible 8-bit target byte values will 



C: Unaffected 

Z: Set if the translation value loaded into RHl is zero; cleared otherwise 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


IR: 


TRTDB @Rsll, @Rs2l, r 








25 












10 


1 1 1000 


Rsl *Q 


1010 






10 


1 1 1000 


Rs1 # 1 1 




25 




0000 


r 


Rs2:^ 


0000 


0000 


r 


RS2:^0 


0000 





















Example: 



In nonsegmented mode, if register R6 contains %4001, the byte at location %4001 
contains 3, register R9 contains %1000, the byte at location %1003 contains %AA, 
and register R12 contains 2, the instruction 

TRTDB @R6, @R9, R12 



Will leave the value %AA in RHl, the value o/o4000 in R6, and the value 1 in R12. 
Location %4001 and register R9 will not be affected. The Z and V flags will be 
cleared. In segmented mode, register pairs must be used instead of R6 and R9. 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
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TRTDRB 

Translate, Test, Decrement and Repeat 



TRTDRB src 1, src 2, R 



src 1: IR 
src 2: IR 



Operation: RHl -*- src 2[srcr] 

AUTODECREMENT srcl by 1 

r ■*- r - 1 

repeat until RHl = or r = 



Flags: 



This instruction is used to scan a string of bytes testing for bytes with special 
meaning. The contents of the location addressed by the first source register (the 
^'target byte") are used as an index into a table of translation values whose lowest 
address is contained in the second source register. The index is computed by adding 
the target byte to the address contained in the second source register. The addition 
is performed following the rules for address arithmetic, with the target byte treated 
as an unsigned 8-bit value extended with high-order zeros. The sum is used as the 
address of an 8- bit value within the table which is loaded into register RHl. The Z 
flag is set if the value loaded into RHl is zero; otherwise the Z flag is cleared. The 
contents of the locations addressed by the source registers are not affected. The first 
source register is then decremented by one, thus moving the pointer to the previous 
element in the string. The word register specified by "r" (used as a counter) is then 
decremented by one. The entire operation is repeated until either the Z flag is clear, 
indicating that a non-zero translation value was loaded into RHl, or until the result 
of decrementing r is zero. This instruction can translate and test from 1 to 
65536 bytes. The source, destination, and counter registers must be separate and 
non-overlapping registers. 

Target byte values which have corresponding zero translation-table entry values are 
to be scanned over, while target byte values which have corresponding non-zero 
translation-table entry values are to be detected. Because the 8-bit target byte is 
added to the second source register to obtain the address of a translation value, the 
table may contain 256 bytes. A smaller table size may be used where it is known that 
not all possible 8-bit target byte values will occur. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter of the start of this instruction is saved before the interrupt request 
is accepted, so that the instruction can be properly resumed. Seven cycles should be 
added to this instruction's execution time for each interrupt request that is accepted. 

C: Unaffected 

Z: Set if the translation value loaded into RHl is zero; cleared otherwise 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 




TRTDRB@Rsl^,@Rs2^r 








11 + 14n 










IR: 




10 


1 1 1000 


Rsl * 


1110 






10 


1 1 1000 


Rs1 =^0 


1110 




11 + 14n 




0000 


r 


ns2* 


1110 


0000 


r 


Rs2 *0 


1110 
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Example: In nonsegmented mode, if register R6 contains °/o4002, the bytes at locations %4000 

through %4002 contain the values %00, %40, %80, repectively, register R9 contains 
%1000, the translation table from location %1000 through %10FF contains 0, 1, 
2, ..., o/o7F, 0, 1,2, ..., %7F (the second zero is located at %1080), and register 
R12 contains 3, the instruction 



TRTDRB @R6, @R9, R12 

will leave the value %40 in RHl (which was loaded from location °/ol040). Register 
R6 will contain %4000, and R12 will contain 1. R9 will not be affected. The Z and V 
flags will be cleared. In segmented mode, register pairs are used instead of R6 
and R9. 



%4000 


00000000 


%4001 


10 


%4002 


10 



%1000 


00000000 


%1001 


1 


%1002 


10 


• 
• 


• 
• 


%107F 


1111111 


%1080 


0000 000 


%1081 


1 


%1082 


10 


• 
• 
• 


• 
• 


%10FF 


1111111 



Note 1 : Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements translated. 
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TRTIB 

Translate, Test and Increment 



TRTIB src 1 , src 2, R 



src 1: IR 
src 2: IR 



Operation: RHl ■*- src2[srcl] 

AUTOINCREMENT srcl by 1 
r -«- r - 1 



Flags: 



This instruction is used to scan a string of bytes testing for bytes with special 
meaning. The contents of the location addressed by the first source register (the 
"target byte") are used as an index into a table of translation values whose lowest 
address is contained in the second source register. The index is computed by adding 
the target byte to the address contained in the second source register. The addition 
is performed following the rules for address arithmetic, with the target byte treated 
as an unsigned 8-bit value extended with high-order zeros. The sum is used as the 
address of an 8-bit value within the table which is loaded into register RHl. The Z 
flag is set if the value loaded into RHl is zero; otherwise the Z flag is cleared. The 
contents of the locations addressed by the source registers are not affected. The first 
source register is then incremented by one, thus moving the pointer to the next ele- 
ment in the string. The word register specified by "r" (used as a counter) is then 
decremented by one. The second source register is unaffected. The source, destina- 
tion, and counter registers must be separate and non-overlapping registers. 

Because the 8-bit target byte is added to the second source register to obtain the 
address of a translation value, the table may contain 256 bytes. A smaller table size 
may be used where it is known that not all possible 8-bit target byte values 
will occur. 

C: Unaffected 

Z: Set if the translation value loaded into RHl is zero; cleared otherwise 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 



Assembler Language 
Syntax 



Nonsegmented Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



IR: 



TRTIB @Rsll, @Rs2l, r 



10 


1 1 1000 


Rsl * 


0010 


0000 


r 


Rs2 ^0 


0000 



25 



10 


1 1 1000 


Rs1 :;t 


0010 


0000 


r 


Rs2*0 


0000 



25 
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Example: This instruction can be used in a "loop" of instructions which translate and test a 

string of data, but an intermediate operation on each data element is required. The 
following sequence outputs a string of 72 bytes, with each byte of the original string 
translated from its 7-bit ASCII code to an 8-bit value with odd parity. Lower case 
characters are translated to upper case, and any embedded control characters are 
skipped over. The translation table contains 128 bytes, which assumes that the most 
significant bit of each byte in the string to be translated is always zero. The first 32 
entries and the 128th entry are zero, so that ASCII control characters and the 
"delete" character (%7F) are suppressed. The given instruction sequence is for 
nonsegmented mode. In segmented mode, register pairs would be used instead of R3 
and R4. 



LOOP: 



LD 


R5, #72 


! initialize counter! 


LDA 


R3, STRING 


Iload start address! 


LDA 


R4, TABLE 




TRTIB 


@R3, @R4, R5 


! translate and test next byte! 


JR 


Z, LOOP 


!skip control character! 


OUTB 


PORTn, RHl 


! output characters! 


JR 


NOV, LOOP 


! repeat until counter = 0! 



DONE: 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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TRTIRB 

Test, Increment and Repeat 



TRTIRB src 1, src2, R 



src 1: IR 
src 2: IR 



Operation: RHl ^ src2[srcl] 

AUTOINCREMENT srcl by 1 

r -*- r - 1 

repeat until RHl = or R = 



Flags: 



This instruction is used to scan a string of bytes, testing for bytes with special 
meaning. The contents of the location addressed by the first source register (the 
"target byte") are used as an index into a table of translation values whose lowest 
address is contained in the second source register. The index is computed by adding 
the target byte to the address contained in the second source register. The addition 
is performed following the rules for address arithmetic, with the target byte treated 
as an unsigned 8-bit value extended with high-order zeros. The sum is used as the 
address of an 8-bit value within the table which is loaded into register RHl. The Z 
flag is set if the value loaded into RHl is zero; otherwise the Z flag is cleared. The 
contents of the locations addressed by the source registers are not affected. 

The first source register is then incremented by one, thus moving the pointer to the 
next element in the string. The word register specified by "r" (used as a counter) is 
then decremented by one. The entire operation is repeated until either the Z flag is 
clear, indicating that a non-zero translation value was loaded into RHl, or until the 
result of decrementing r is zero. This instruction can translate and test from 1 to 
65536 bytes. The source, destination, and counter registers must be separate and 
non-overlapping registers. 

Target byte values which have corresponding zero translation table entry values are 
scanned over, while target byte values which have corresponding non-zero transla- 
tion table entry values are detected and terminate the scan. Because the 8-bit target 
byte is added to the second source register to obtain the address of a translation 
value, the table may contain 256 bytes. A smaller table size may be used where it is 
known that not all possible 8-bit target byte values will occur. 

This instruction can be interrupted after each execution of the basic operation. The 
program counter of the start of this instruction is saved before the interrupt request 
is accepted, so that the instruction can be properly resumed. Seven cycles should be 
added to this instruction's execution time for each interrupt request that is accepted. 

C: Unaffected 

Z: Set if the translation value loaded into RHl is zero; cleared otherwise 

S: Unaffected 

V: Set if the result of decrementing r is zero; cleared otherwise 

D: Unaffected 

H: Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles2 


Instruction Format 


Cycles2 


IR: 


TRTIRB @Rsll, @Rs2l, r 








11-H4n 










10 


1 1 1000 


Rs1 ^0 


0110 






1 


11 1000 


Rsl * 


01 10 


11 +14n 




0000 


r 


Rs2^0 


1110 


0000 


r 


Rs2#0 


1110 
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Example: The following sequence of instructions can be used in nonsegmented mode to scan a 

string of 80 bytes, testing for special characters as defined by corresponding non- 
zero translation table entry values. The pointers to the string and translation table 
are set, the number of bytes to scan is set, and then the translation and testing is 
done. The Z and V flags can be tested after the operation to determine if a special 
character was found and whether the end of the string has been reached. The 
translation value loaded into RHl might then be used to index another table, or to 
select one of a set of sequences of instructions to execute next. In segmented mode, 
R4 and R5 must be replaced with register pairs. 





LDA 


R4, STRING 




LDA 


R5, TABLE 




LD 


R6, #80 




TRTIRB 


@R4, @R5, R6 




JR 


NZ, SPECIAL 


END_OF_ 


.STRING: 




SPECIAL: 







JR 



OV,LAST_CHAR_SPECIAL 



L AST_CH AR_SPECI AL : 



Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
Note 2: n = number of data elements translated. 
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TSET 

Test and Set 



TSET dst 
TSETB 



dst: R, IR, DA, X 



Operation: S -^ dst(msb) 

dst(0:msb) *- 111. ..Ill 



Flags: 



Tests the most significant bit of the destination operand, copying its value into the S 
flag, then sets the entire destination to all 1 bits. This instruction provides a locking 
mechanism which can be used to synchronize software processes which require 
exclusive access to certain data or instructions at one time. 



During the execution of this instruction, BUSRQ is not honored in the time between 
loading the destination from memory and storing the destination to memory. For 
systems with one processor, this ensures that the testing and setting of the destination 
will be completed without any intervening accesses. This instruction should not be 
used to synchronize software processes residing on separate processors where the 
destination is a shared memory location, unless this locking mechanism can be 
guaranteed to function correctly with multi-processor accesses. 



C: 
Z: 
S: 
V: 
D: 
H: 



Unaffected 

Unaffected 

Set if the most significant bit of the destination was 1 ; cleared otherwise 

Unaffected 

Unaffected 

Unaffected 



Addressing 
Mode 


Assembler Language 
Syntax 


Nonsegmented Mode 


Segmented Mode 


Instruction Format 


Cycles 


Instruction Format 


Cycles 


R: 


TSET Rd 
TSETB Rbd 

TSET @Rdi 
TSETB @Rdi 

TSET address 
TSETB address 

TSET addr(Rd) 
TSETB addr(Rd) 








7 
11 

14 
15 










1 


001 10 


W 


Rd 


0110 






1 


00110 


W 


Rd 


0110 


7 


IR: 
















00 


00110 


W 


Rd:^0 


0110 






00 00110 


W 


Rd^O 


0110 


11 
















DA: 




01 


00110 


W 


0000 


0110 




SS 


01 


0110 


W 


0000 


0110 


15 




address 





segment 


offset 1 






















SL 


01 


001 1 


W 


0000 


0110 






1 


segment 


0000 0000 1 


17 




offset 


















X: 




01 


00110 


W 


Rd:)t0 


0110 




SS 


01 


001 10 


W 


Rd?iO 


0110 


15 




address 





segment 


offset 




















SL 


01 


00110 


« 


Rd:^0 


01 10 1 






1 


segment 


0000 0000 


18 




offset 
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Example: A simple mutually-exclusive critical region may be implemented by the following 

sequence of statements: 

ENTER: 

TSET SEMAPHORE 

JR MI, ENTER Hoop until resource con-! 

! trolled by SEMAPHORE! 

!is available! 

! Critical Region — only one software process! 
! executes this code at a time! 



CLR SEMAPHORE ! release resource controlled! 

!by SEMAPHORE! 
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XOR 

Exclusive Or 



XOR dst, src 
XORB 



dst: R 

src: R, IM, IR, DA, X 



Operation: 



dst ■*- dst XOR src 



Flags: 



The source operand is logically EXCLUSIVE ORed with the destination operand and 
the result is stored in the destination. The contents of the source are not affected. 
The EXCLUSIVE OR operation results in a one bit being stored whenever the cor- 
responding bits in the two operands are different; otherwise, a zero bit is stored. 

C: Unaffected 

Z: Set if the result is zero; cleared otherwise 

S: Set if the most significant bit of the result is set; cleared otherwise 

P: XOR — unaffected; XORB — set if parity of the result is even; cleared otherwise 

D: Unaffected 

H: Unaffected 



Source 

Addressing 

Mode 



Assembler Language 
Syntax 



Nonsegmenied Mode 



Instruction Format 



Cycles 



Segmented Mode 



Instruction Format 



Cycles 



R: 
IM: 



IR: 
DA: 



X: 



XOR Rd, Rs 
XORB Rbd, Rbs 

XOR Rd, #data 



XORB Rbd, #data 



XOR Rd, @Rsi 
XORB Rbd, @Rsi 

XOR Rd, address 
XORB Rbd, address 



XOR Rd, addr(Rs) 
XORB Rbd, addr(Rs) 



10 


00100 


w 


Rs 


Rd 1 



00 001001 0000 Rd 



data 



00 001000 


0000 Rd 


data 


data 



00100 W Rs^to Rd 



0100100WOOOO Rd 



01 00100 W Rs^O Rd 



address 



10 





10 


00100 W 


Rs 


Rd 








00 


1 001 001 


0000 


Rd 1 




data 








00 


1 001 000 


0000 


Rd J 




data 


data 1 








00 00100 


W 


Rst^O 


Rd 






ss 


01 


001 00 


W 


0000 


Rd 





segment 


offset 1 








01 


00100 


W 


0000 


Rd 


SL 


1 


segment 


0000 0000 I 




offset 






88 


01 


00100 


W 


Rs*0 


Rd 





segment 


offset I 








01 


00100 


V, 


Rs^^tO 


Rd 1 


SL 


1 


segment 


0000 0000 




offset 1 



10 



12 



10 



13 



6-165 



Example: If register RL3 contains %C3 (11000011) and the source operand is the immediate 

value %7B (01 1 1 101 1), the statement 

XORB RL3,#%7B 

will leave the value %B8 (10111000) in RL3. 

Note 1: Word register in nonsegmented mode, register pair in segmented mode. 
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6.8 EPA There are seven "templates" for EPA instruc- 

Instruction tions. These templates correspond to EPA 
Templates instructions, which combine EPU operations 

with possible transfers between memory and an 
EPU, between CPU registers and EPU regis- 
ters, and between the Flag byte of the CPU's 
FCW and the EPU. Each of these templates is 
described on the following pages. The descrip- 
tion assumes that the EPA control bit in the 
CPU's FCW has been set to 1 . In addition, the 
description is from the point of view of 
the CPU— that is, only CPU activities are 
described; the operation of the EPU is implied. 



but the full specification of the instruction 
depends upon the implementation of the EPU 
and is beyond the scope of this manual. 

Fields ignored by the CPU are shaded in the 
diagrams of the templates. The 2-bit field in bit 
positions and 1 of the first word of each 
template would normally be used as an identi- 
fication field for selecting one of up to four 
EPUs in a multiple EPU system configuration. 
Other shaded fields would typically contain 
opcodes for instructing an EPU as to the oper- 
ation it is to perform in addition to the data 
transfer specified by the template. 



Extended Instruction 

Load Memory from EPU 



Operation: 



Memory -«- EPU 



The CPU performs the indicated address calculation and generates n EPU memory 
write transactions. The n v^ords are supplied by an EPU and are stored in n con- 
secutive memory locations starting with the effective address. 

Flags/Registers: No flags or CPU registers are affected by this instruction. 



mode 


00 11 11 


dst 


1 1 


''*-'"",: 






Clock Cycles 




:X^-i 




n-1 




mod< 


s dst 


NS 


SS 


SL 





IR (dst ^ 0) 


ll+3n 






1 


X (dst ^ 0) 


15 + 3n 


15 + 3n 


18 4-3n 


1 


E 


A 


(ds 


t = 


0) 


14 + 3n 


15 + 3n 


17 + 3n 
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Extended Instruction 

Load EPU from Memory 



Operation: 



EPU -«- Memory 



The CPU performs the indicated address calculation and generates n EPU memory- 
read transactions. The n consecutive words are fetched from the memory locations 
starting with the effective address. The data is read by an EPU and operated upon 
according to the EPA instruction encoded into the shaded fields. 

Flags/Registers: No flags or CPU registers are affected by this instruction. 



mode 001111 src 01i 



mode 



'^MiM^mm&kklLMk. "''' 



NS 



Clock Cycles 
__ 



SL 




1 
1 



IR (src =^ 0) 

X (src ^ 0) 

DA (src = 0) 



ll+3n 
15 + 3n 
14 + 3n 



15 + 3n 
15 + 3n 



18 + 3n 
17 + 3n 



Extended Instruction 

Load CPU from EPU 



Operation: 



CPU *- EPU registers 



The contents of n words are transferred from an EPU to consecutive CPU registers 
starting with register dst. CPU registers are transferred consecutively, with register 
following register 15. 

Flags/Registers: No flags are affected by this instruction. 

Execution Time: 11 + 3n cycles. 



10 0011 11 



'^m- 
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Extended Instruction 

Load EPU from CPU 



Operation: EPU -*- CPU registers 

The contents of n words are transferred to an EPU from consecutive CPU registers 
starting with register src. CPU registers are transferred consecutively, with register 
following register 15. 

Flags/Registers: No flags are affected by this instruction. 

Execution Time: 11 + 3n cycles. 



10 0011 11 



\f src 






10 ? 



Extended Instruction 

Load FCW from EPU 



Operation: Flags -*- EPU 

The Flags in the CPU's Flag and Control Word are loaded with information from an 
EPU on AD lines ADq-AD?. 

Flags/Registers: The contents of CPU register are undefined after the execution of this instruction. 

Execution Time: 14 cycles. 



10 0011 10 






,i|^ 
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Extended Instruction 

Load EPU from FCW 



Operation: EPU -•- Flags 

The Flags in the CPU's Flag and Control Word are transferred to an EPU on AD 
lines AD0-AD7. 

Flags/Registers: The flags in the FCW are unaffected by this instruction. 

Execution Time: 14 cycles. 



100011 10 




10 




00 00 




0000 



Extended Instruction 

Internal EPU Operation 



Operation: Internal EPU Operation 

The CPU treats this template as a No Op. It is typically used to initiate an internal 
EPU operation. 

Flags/Registers: The flags in the FCW are unaffected by this instruction. 

Execution Time: 14 cycles. 



100011 10 
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Chapter 7 
Exceptions 



7.1 Intro- The Z8000 CPU supports three types of 

duction exceptions (conditions that can alter the nor- 

mal flow of program execution): 

■ interrupts 

■ traps 

■ reset 

Interrupts are asynchronous events typically 
triggered by peripheral devices needing atten- 
tion. They cause the processor to temporarily 
suspend its present program execution in 
order to service the reguesting device. Traps 
are synchronous events that are responses by 
the CPU to certain events detected during the 



attempted execution of an instruction. Thus, 
the major distinction between traps and inter- 
rupts is their origin: a trap condition is always 
reproducible by re-executing the program that 
created the traps, whereas an interrupt is 
generally independent of the currently exe- 
cuting task. A reset overrides all other condi- 
tions, including all inter rupts and traps. It 
occurs when the RESET line is activated, and it 
causes certain control registers to be initial- 
ized. The action that the Z8000 CPU takes in 
response to an interrupt, trap, or reset is 
similar; hence, they are treated together in this 
chapter. 



7.2 Interrupts Three kinds of interrupts are activated by 
three different pins on the Z8000 CPU. (Inter- 
rupt handling for all interrupts is discussed in 
Section 7.6.) 

7.2.1 Non-Maskable Interrupt (NMI). 

This type of interrupt cannot be disabled 
(masked) by software. It is typically reserved 
for highest-priority external events that require 
immediate attention. 

7.2.2 Vectored Interrupt (VI). One result of 
any interrupt or trap is that a 16-bit identifier 
word is pushed onto the system stack (see Sec- 
tion 7.6.2). This word may be used to identify 
the source of the interrupt or trap. In vectored 
interrupts, this identifier is also used by the 



CPU hardware as a pointer to select a particu- 
lar interrupt service routine. The processing of 
vectored interrupts is thus considerably faster 
than would be the case if a general trap hand- 
ler had to first examine the identifier, then 
branch off to the appropriate service routine. 
These interrupts can be disabled by software. 

7.2.3 Nonvectored Interrupts (NVI). These 
interrupts also result in an identifier word 
being pushed onto the system stack. However, 
the CPU does not use the identifier as a vector 
to select a service routine: all non- vectored 
interrupts are serviced by the same routine. 
They can be disabled by software. 



7.3 Traps The Z8001 and Z8002 CPUs support three 

traps generated internally. The Z800I supports 
a fourth trap, which is generated externally 
(but synchronously) by the Memory Manage- 
ment Unit. Since a trap always occurs when all 
Its defining conditions are present, traps can- 
not be disabled. (Trap handling operations are 
discussed in Section 7.6.) 

7.3.1 Extended Instruction Trap. This trap 
occurs when the CPU encounters an extended 
instruction (see Section 6.2.10) while the EPA 
bit in the FCW is cleared. This trap allows the 
program to simulate the operations of the EPU 
when none is present in the system or to abort 
the program. 

7.3.2 Privileged Instruction Trap. This trap 
occurs whenever an attempt is made to execute 
a privileged instruction while the CPU is in 
normal mode (S/N bit in the FCW is cleared). 



This trap allows the CPU to detect and prevent 
operation (such as I/O) that could disable the 
system. 

7.3.3 System Call Trap. This trap occurs 
whenever a System Call (SC) instruction is 
executed. It allows an orderly transition to be 
made between normal mode and system mode. 

7.3.4 Se gment Trap. This trap occurs when 
ever the SEGT line is asserted on a Z8001 , 
regardless of the state of the SEG bit in the 
FCW. This trap is generated by external 
memory management hardware, such as the 
Z80I0 Memory Management Unit (MMU), and 
is the result of detecting a memory access 
violation (such as an offset larger than the 
assigned segment length) or a write warning 
(a write into the lowest 256 bytes of a stack). 
See the MMU Technical Manual for more 
information on memory management hardware. 
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7.4 Reset A reset initializes selected control registers 

of the CPU to system specifiable values. A 
reset can occ ur at th e end of any clock cycle, 
provided the RESET line is Low. 

A system reset overrides all other consider- 
ations, including interrupts, traps, bus 
requests, and stop requests. A reset should be 
used to initialize a system as part of the power- 
up sequence. 

Within five clock cycles of the RESET 
becom i ng Low , ADp-ADi s are 3-sta ted; 
AS,DS, MREQ, BUSACK, and MO are forced 
High; ST0-ST3 are forc_ed High and SNo_- SNg 
are forced Low . The R /W, B/W, and N/S lines 
are undefined. RESET must be held Low five 



clock cycles to properly re set the CPU. 

Three clock cycles after RESET has returned 
to High, consecutive memory read cycles are 
executed in system mode to initialize the Pro- 
gram Status registers. In the Z8001, the first 
cycle reads the FCW from location 0002, the 
next reads the PC from location 0004, and the 
following initial instruction fetch cycle starts 
the program. Each of these fetches is made 
from system program address space. In the 
Z8002, the first cycle reads the PC from loca- 
tion 0004 and the following initial instruction 
fetch cycle starts the program. Each of these 
fetches is made from the program address 
space. 



7.5 Interrupt Vectored and nonvectored interrupts can be 

Disabling enabled or disabled independently via software 

by setting or clearing appropriate control bits 
in the Flag and Control Word (FCW). Two 
control bits in the FCW control the maskable 
interrupts: VIE and NVIE. Any control bit may 
be changed by automatically loading a new 
FCW during an interrupt or trap acknowledge 
sequence and may be restored to its previous 
setting by an Interrupt Return (IRET) instruc- 
tion. When VIE is 1 , vectored interrupts are 
enabled; when NVIE is I , non-vectored inter- 
rupts are enabled. These two flags may be set 



or cleared together or separately. In addition, 
these control bits are set when the FCW is 
loaded. Any control bit may be changed by 
the occurrence of an interrupt or trap and then 
be restored to its previous setting by an Inter- 
rupt Return (IRET) instruction. 

When a type of interrupt has been disabled, 
the CPU ignores any interrupt request on the 
corresponding input pin. Because maskable 
interrupt requests are not retained by the 
CPU, the request signal must be asserted until 
the CPU acknowledges the request. 



7.6 Interrupt The CPU response to a trap or interrupt 

and Trap request consists of five steps: acknowledging 

Handling the external request (for interrupts and seg- 

ment traps), saving the old program status 
information, loading a new program status, 
executing the service routine, and returning to 
the interrupted task. Interrupt timing is shown 
on page A-2. 

7.6.1 Acknowledge Cycle. An external 
acknowledge cycle is required only for exter- 
nally generated requests. As described in 
Chapter 9, the main effect of such a cycle is to 
receive from the external device a 16-bit iden- 
tifier word, which will be saved with the old 
program status. Before the acknowledge cycle, 
the CPU enter_s_ segmented (Z8001 only) system 
mode. (The N/S line indicates that a transition 
has been made to system mode.) The old FCW 
is not affected by this change in mode. The 
CPU remains in this mode until it begins to 
execute the exception service routine, at which 
time its mode is dictated by the FCW. 

7.6.2 Status Saving. The old program status 
information is saved by being pushed on the 
system stack in the following order: the Pro- 
gram Counter (PC: 16 bits for Z8002; 16-bit 
offset followed by a word containing the 7-bit 



segment number for Z8001); the Flag and Con- 
trol Word (FCW); and finally, the interrupt/ 
trap identifier word. The identifier word con- 
tains the reason or source of the trap or inter- 
rupt. For internal traps, the identifier is the 
first word of the trapped instruction. For seg- 
ment trap or interrupts, the identifier is the 
value on the data bus read by the CPU 
during the interrupt-acknowledge or trap- 
acknowledge cycle. The format of the saved 
program status in the system stack is illustrated 
in Figure 7.1. 



SYSTEM STACK 
POINTER AFTER 
TRAP OR 
INTERRUPT 



SYSTEM STACK 
POINTER BEFORE 
TRAP OR 
INTERRUPT 



SYSTEM SP 
AFTER TRAP 
OR INTERRUPT 



SYSTEM SP 
BEFORE TRAP 
OR INTERRUPT 



Figure 7-1. Format of Saved Program Status in the 
System Stack 
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7,6 Interrupt The following table shows the PC value that 
and Trap is pushed on the stack for each type of inter- 
Handling rupt and trap. 
(Continued) Exception: PC Value Is Address of: 



Extended Instruction Trap 



Privileged Instruction Trap 



System Call Trap 
Segment Trap 
All Interrupts 



Next Instruction 

(Single Word Privileged 

Instruction) 
Second Word of Instruction 

(Multiple Word Privileged 

Instruction) 
Next Instruction 
Next Instruction* t 
Next Instruction t 



* Assumes successlul completion of instruction fetch 
t If executing an interruptable instruction (e.g. LDIR) 

and the instruction has not completed, then the next 

instruction is the current instruction. 

7.6.3 Loading New Program Status. After 
saving the current program status, the new 
program status (PC and FCW) is automatically 
loaded from the Program Status Area in system 
program memory. The particular status words 
fetched from the Program Status Area are a 
function of the type of trap or interrupt and 
(for vectored interrupt) of the interrupt vector. 
Figure 7.2 shows the format of the Program 
Status Area. 

For each kind of interrupt or trap other than 
a vectored interrupt, there is a single program 
status block that is automatically loaded into 
the Program Status registers (which includes 
the Flag and Control Word and the Program 
Counter). 

Note that the size of each program status 
block depends on the version of the Z8000 (two 
words for the nonsegmented Z8002 and four 
words for the segmented Z8001). 

For all vectored interrupts, the same Flag 
and Control Word (FCW) is loaded from the 
corresponding program status block. However, 
the appropriate Program Counter (PC) value is 
selected from up to 256 (Z8002) or 128 (Z8001) 
different values in the Program Status Area. 
The low-order eight bits of the identifier 
placed on the data bus by the interrupting 
device is multiplied by two and used as an off- 
set into the Program Status Area following the 
FCW for vectored interrupts. On the Z8002, 
the identifier value selects the first PC value, 
the value 1 selects the second PC, and so on 
up to the identifier value 255. On the Z8001, 
the identifier value selects the first PC value. 



the value 2 selects the second PC, and so on 
up to the identifier value 254, which selects 
the 128th PC value. All vectors on Z8001 
systems must be even. 

The Program Status Area is addressed by a 
special control register, the Program Status 
Area Pointer, or PSAP. This pointer is one 
word for the nonsegmented Z8002 and two 
words for the segmented Z8001. As shown in 
Figure 7.2, the pointer contains a segment 
number (if applicable) and the high-order byte 
of a 16-bit offset address. The low-order byte is 
assumed to contain zeros; thus the Program 
Status Area must start on a 256-byte address 
boundary. The programmer accesses the PSAP 
using the Load Control Register instruction 
(LDCTL). 
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Figure 7-2. Program Status Area 
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7.6 Interrupt 7.6.4 Executing the Service Routine. Loading 
and Trap the new program status automatically initializes 

Handling the Program Counter to the starting address of 

(Continued) the service routine to process the interrupt or 
trap. This program is now executed. Because a 
new FCW was loaded, the maskable interrupts 
can be disabled for the initial processing of the 
service routine by a suitable choice of FCW. 
This allows critical information to be stored 
before subsequent interrupts are handled. Ser- 
vice routines that enable interrupts before exit- 
ing permit interrupts to be handled in a nested 
fashion. 



7.6.5 Returning from an Interrupt or Trap. 

Upon completion, the service routine can exe- 
cute an Interrupt Return instruction, IRET, to 
cause execution to continue at the point where 
the interrupt or trap occurred. IRET causes 
information to be popped from the system stack 
in the following order: the identifier is dis- 
carded, the saved FCW and PC are restored. 
The newly loaded FCW takes effect with the 
next fetched instruction, which is determined 
by the restored Program Counter. 

On Z8001 CPUs, IRET can be executed only 
in segmented mode; in nonsegmented mode 
the operation is undefined. 



7.7 Priority Because it is possible for several exceptions 

to occur simultaneously, the CPU enforces a 
priority scheme for deciding which event will 
be honored first. The following gives the 
descending priority order: 

■ Reset 

■ Internal Trap (i.e., privileged instruction, 
system call, extended instruction) 

■ Non-Maskable Interrupt 

■ Segment Trap (Z8001 only) 

■ Vectored Interrupt 

m Nonvectored Interrupt 

This is how the priority system works: 

■ Whenever a reset is requested, it is immedi- 
ately performed. 

■ If several non- reset exceptions occur simul- 
taneously, the one that has the highest 
priority and is also enabled (traps and non- 
maskable interrupts are always enabled) is 
acknowledged, old status is saved, and new 
status is loaded. The new status consists of 
the starting address of the service routine 
(PC) and a new FCW that may disable vec- 
tored and nonvectored interrupts. 

■ If any enabled exceptions remain, the 
highest-priority one is acknowledged, the 
old status is saved, and the new status is 
loaded. Note that in this case, the old status 
is the PC and FCW of the previous excep- 
tion's service routine. 



■ This process is repeated until no enabled 
exceptions remain. At that point, the cur- 
rent PC and FCW will contain the status 
values for the lowest priority exception that 
was acknowledged. 

■ The execution of the service routines now 
proceeds in reverse priority order. That 
is, the lowest priority exception is 
serviced first. 

■ After all the exceptions have been serviced, 
the original status is restored and execution 
resumes. 

Within each of the classes above, there can 
be multiple-interrupt sources. The internal 
traps are mutually exclusive and therefore 
need no priority resolution within that class. 
The other types arise from external sources; 
thus when multiple devices share the same 
request line, the possibility arises that more 
than one device may request service from the 
CPU simultaneously. Either all the interrupt 
sources must be serviced simultaneously (as 
with the MMU) or competing requests must be 
resolved externally to the CPU, for example, 
by means of a daisy-chain or priority interrupt 
controller. This resolution is done during the 
interrupt acknowledge cycle. 
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Chapter 8 
Refresh 



8.1 Intro- The Z8000 CPU has an internal mechanism 

duction for refreshing dynamic memory. This 

mechanism can be activated in two ways: 

■ When the Refresh Enable (RE) bit in the 
CPU Refresh Counter is set to one (Figure 
8.1), memory refresh is performed period- 
ically at a rate specified by the RATE field 
in the counter. (See Section 8.3.) 



When the STOP line is activated, the CPU 
generates memory refreshes continuously. 
(See Section 8.4.) 

\ — I I I I — I— I — I — ^—^— I — i-H — I — I— I 



E 



ROW ADDRESS 



nTTTTTTT 

ADs AD7 AOe ADs AD4 AD3 AD2 AD^ ADg 

Figure 8-1. Refresh Control Register 



8.2 Refresh The refresh mechanism is a way of gener- 

Cycles ating a special kind of bus transaction called a 

refresh cycle, which is described in Chapter 9. 

A refresh cycle is three clock cycles long and 

may be inserted immediately after the last 

clock cycle of any transaction. 

During a refresh cycle, the status lines are 

set to 0001 and the address lines ADi-ADs are 



set to the value of the row address counter. 
Address lines AD9-AD15 are undefined, and 
ADo is always 0. The ROW value determines 
the memory row that is being refreshed on this 
cycle. Since memory is word-organized, ADq 
is always zero. After the refresh cycle is com- 
plete, the ROW field is incremented by two, 
thus stepping through 256 rows. 



8.3 Periodic The Refresh Enable (RE) bit controls only 

Refresh Periodic Refresh; ref resh c ycles may be 

generated using the STOP line, regardless of 
the state of RE. When RE is set to one, the 
value of the 6-bit RATE field determines the 
time between successive refreshes (the refresh 
period). When RATE - 0, the refresh period 
is 256 clock cycles; when RATE = n, the 
refresh period is 4n clock cycles. (Thus, if 
there is a 4 MHz clock, the refresh period can 
be from 1 fis to 64 /tis.) 

The LDCTL instruction is used to set the 
refresh rate, to set or clear RE, or to initialize 
or read the ROW field. (See Section 6.7 for a 
detailed discussion of this instruction.) 

The refresh cycle is generated as soon as 
possible after the refresh period has elapsed. 
This usually means after the last clock cycle of 
the current transaction. If the CPU receives a 



trap or an interrupt simultaneously with a 
Periodic Refresh request, the refresh operation 
is performed first. 

When the CPU does not h ave control of the 
bus (that is, when BUSACK is asserted and the 
CPU e nters Bus-Disconnect state) or when the 
WAIT line is deactivated, the CPU issues the 
skipped refresh cycles. To deal with this situa- 
tion, both Z8000 CPUs have internal circuitry 
that records when the refresh period has 
elapsed and refresh cycles cannot be gener- 
ated. When the CPU re gains control of the 
bus, or when the WAIT line is reactivated, it 
immediately issues the skipped refresh cycles. 
The internal circuitry can record up to two 
such skipped refresh operations. 

After a reset operation. Periodic Refresh is 
disabled (RE is cleared) and the internal cir- 
cuitry that counts skipped refreshes is cleared. 



8.4 Stop-State The CPU has three internal operating states: 
Refresh Running, Stop, and Bus-Disconnect states (see 

Section 2.8). Stop state is entered during the 
first word fetch of an instruction if STOP is 
activated before the machine cycle begins, or 
during the second word fetch of an EPA 



instruction if the STOP line is activat ed befo re 
the start of the machine cycle. When STOP is 
found High again, one more refresh cycle is 
performed, then the remaining clock cycles of 
the instruction fetch are executed. (See 
Appendix A for more timing information.) 
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Chapter 9 
External Interface 



9.1 Intro- This chapter covers the external manifesta- 

duction tions (e.g., the activity on the CPU pins) that 

result from the operations described in 
Chapters 2 through 8. Since the pins are con- 
nected to the system bus (see Figure 2.3 in 
Chapter 2), much of the discussion will center 



on the bus and bus operations. The Z8000 CPU 
is designed to be compatible with the Zilog 
Z-Bus protocols, which are described in the 
Z-Bus Summary. In the sections that follow, the 
interface between the Z8000 CPU and its 
environment is described in detail. 



9.2 Bus Two kinds of operations can occur on the 

Operations system bus: transactions and requests. At any 
given time, one device (either the CPU or a 
bus requester, such as the Z8016 DMA Con- 
troller) has control of the bus and is known as 
the bus master. A transaction is initiated by 
the bus master and is responded to by some 
other device on the bus. Only one transaction 
can proceed at a time; six kinds of transactions 
can occur: 

■ Memory transaction. This type is used to 
transfer eight or 16 bits of data to or from a 
memory location (Section 9.4.2). 

■ I/O transaction. This type is used to transfer 
eight or 16 bits of data to or from a periph- 
eral or CPU support component, such as an 
MMU (Section 9.4.3). 

■ EPU transfer. This type is used to transfer 
16 bits of data between the CPU and an EPU 
(Section 9.4.4). 

■ Interrupt/Trap Acknowledge. This type is 
used to acknowledge an interrupt or trap 
and to transfer an identification/status word 
from the interrupting or trapping device 
(Section 9.4.5). 

■ Refresh. These transactions do not transfer 
data. They refresh dynamic memory (Sec- 
tion 9.4.6). 

■ Internal operation. These transactions do 



not transfer data. They indicate that the 
CPU is performing an operation that does 
not require data to be transferred on the bus 
(Section 9.4.6). 

Only the bus master may initiate trans- 
actions. A request, however, may be initiated 
by a component that does not have control of 
the bus. Four types of requests can occur: 

■ Interrupt request. This type is used to 
request the attention of the CPU (Section 
9.6.1). 

■ Bus request. This type is used to request 
control of the bus to initiate transactions 
(Section 9.6.2). 

■ Resource request. This type is used to 
request control of a particular system 
resource (Section 9.6.3). 

■ Stop request. This type is used to delay 
CPU instruction execution (Section 9.6.4). 

When an interrupt or bus request is made, it 
is answered by the CPU according to its type: 
for interrupt request, an interrupt acknowledge 
transaction is initiated; for bus requests, the 
CPU enters Bus Disconnect state, relinquishes 
the bus, and activates an acknowledge signal; 
for stop requests, the CPU stops execution and 
enters Stop/Refresh state. A resource request 
is generated by the CPU when it executes a 
multi-micro request instruction. 
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9.3 CPU Pins The CPU pins can be grouped into five 
categories according to their functions 
(Figure 9.1). 

9.3.1 Transaction Pins. These signals provide 
timing, control, and data transfer for Z-Bus 
transactions. 

ADg-ADis. Address/Data (Output, active High, 
3-state). These multiplexed data and address 
lines carry I/O addresses, memory addresses, 
and data during Z-Bus transactions. For the 
Z8001, only the offset portion of memory 
addresses is carried on these lines. 

SN0-SN7. Segment Number (Z8001 only. Out- 
put, active High, 3-state). These lines contain 
the segment number portion of a memory 
address. 

ST0-ST3. (Output, active. High, 3-state). 
These lines indicate the kind of transaction 
occurring on the bus and give additional 
information about the transaction (such as the 
address space for memory transactions). 

AS. Address Strobe (Output, active Low, 
3-state). The rising edge of AS indicates the 
beginning of a transaction and shows Jhat the 
Address, ST0-ST3, N/S, R/W, and B/W signals 
are valid. 

DS. Da ta S trobe (Output, active Low, 3- 
state). DS provides timing for data movement 
to or from the CPU. 

R/W. Read/Write (Output, Low = Write, 3- 
state). This signal determines the direction of 
data transfer for memory, I/O, or EPU transfer 
transactions. 

B/W. Byte/Word (Output, Low = Word, 
3-state). This signal indicates whether a byte 
or word of data is to be transmitted during a 
transaction. 



WAIT. (Input, active Low). A Low on this line 
indicates that the responding device needs 
more time to complete a transaction. 



MREQ. Memory Request (Output, active Low, 
3-state). A falling edge on this line indicates 
that the address/data bus is holding a memory 
address. 

9.3.2 Bus Control Pins. These pins carry 
signals for requesting and obtaining control of 
the bus from the CPU. 

BUSREQ. Bus Request (Input, active Low). A 
Low indicates that a bus requester has 
obtained or is trying to obtain control of 
the bus. 



BUSACK. Bus Acknowledge (Output, active 
Low). A Low on this line indicates that the 
CPU has relinquished control of the bus in 
response to a bus request. 

9.3.3 Interrupt/ Trap Pins. These pins convey 

interrupt and external trap requests to 

the CPU. 

NMI. Non-Maskable Interrupt (Input, E dge 

activated). A High-to-Low transition on NMI 

requests a non-maskable interrupt. 

NVI. Non- Vectored Interrupt (Input, active 
Low). A Low on this line requests a non- 
vectored interrupt. 

VI. Vectored Interrupt (Input, active Low). A 
Low on this line requests a vectored interrupt. 

SECT. Segment Trap (Z8001 only. Input, 
active Low). A Low on this line requests a seg- 
ment trap. 
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Figure 9-1 . Pin Functions 
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9-3. CPU Pins 9.3.4 Multi-Micro Pins. These pins are the 
(Continued) ZSOOO's interface to the Z-Bus resource request 
lines. 

MI. Multi-Micro In (Input, active Low). This 
input is used to sample the state of the 
resource request lines. 

MO. Multi-Micro Out (Output, active 
Low). This line is used by the CPU to make 
resource requests. 



9.3.5 CPU Control. These pins carry signals 
which control the overall operation of 
the CPU. 



STOP. (Input, active Low). This line is used to 
suspend CPU operation during the fetch of the 
first word of an instruction. 

RESET. (Input, active Low). A Low on this line 
resets the CPU. 



9.4 Trans- Data transfers to and from the CPU are 

actions accomplished through the use of transactions. 

Figure 9.2 shows the general timing for a 

transaction. 



A ll transactions start with Address Strobe 
(AS) being driven Low and then ra ised High 
by the CPU. On the rising edge of AS, the 
status lines ST0-ST3 are valid; these lines indi- 
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Figure 9-2. Transaction Timing 
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9-4. Trans- cate the type of transaction being initiated (see 
actions Table 9.1; the six types of transactions are dis- 

( Continued) cussed in the sections that follow). Associated 
with the status lines are threei other lines that 
become valid at this time. These are Normal/ 
System (N/S), Read/Write (R/W), and 
Byte/Word_(B/W). Except where indicated 
below, N/S designates the operating mode of 
the CPU, R/W designates the direction of data 
transfer (read to the CPU, write from the 
CPU), and B/W designates the length of the 
data item being transferred. 

If the transaction requires an address, it too 
is valid on the rising edge of AS. No address is 
required for interrupt acknowledge, EPU 
transfer, or internal operation transactions. (In 
the Z8001, the segment number lines SNq-SNs 
are valid one clock cycle earlier to allow for 
external memory management hardware. See 
Chapter 2 for more information.) 

The CPU uses Data Strobe (DS) to time the 
actual data transfer. (Note that refresh and 
internal operation transactions do not transfer 

any data and thus do_not activate DS.) For 

write operations (R/W = Low), a Low on DS 
indicates that valid data from the bus master is 
on the ADq-ADjs lines. For read operations 
(R/W = High), the bus master makes 
ADq-ADis 3-state before driving DS Low so 
that the addressed device can put its data on 
the bus. The bus master samples this data on 
the falling clock edge just before raising 
DS High. 



9.4.1 WAIT. As shown in Figure 9.2, WAIT is 
sampled on a falling clock edge one cycle 
before data is sampled by the CPU (Read) or 
DS rises (Read or Write). If WAIT is Low, 
another cycle is added to the transaction 
before data is sampled or DS rises. In this 
added cycle a nd all subs equent cycles added 
due to WAIT being Low, WAIT is again sam- 
pled on the falling edge and, if it is Low, 
another cycle is added to the transaction. In 
this way, the transaction can be extended to an 
arbitrary length to accommodate (for example) 
slow memories or I/O devices that are not yet 
ready for data transfer. 

It must be emphasized that the WAIT input 
is synchronous. Thus, it must meet the setup 
and hold times given in Appendix A in order 
for the CPU to function correctly. This 
requires asynchronously generated WAIT 
signals to be synchronized before they are 
input into the CPU. 

9.4.2 Memory Transactions. Memory Trans- 
actions move data to or from memory when the 
CPU makes a memory access. Thus, they are 
generated during program execution to fetch 
instructions from memory (Chapter 4) and to 
fetch and store memory data (Chapter 5). They 
are also generated to store old program status 
and fetch new program status during interrupt 
and trap handling and after reset (Chapter 7). 

As shown in Figure 9.3, a memory trans- 
action is three clock cycles long unless 
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9-4. Trans- extended as explained above in WAIT. The 
actions status pins, besides indicating a memory trans- 

(Continued) action, give the following information: 

■ Whether the memory access is to the data 
(1000, 1010), stack (1001, 1011), or program 
(1100, 1101) address space (Chapter 3). 

■ Whether the first word of an instruction is 
being fetched (1101). 

■ Whether the data for the access is to be 
supplied (write) or captured (read) by an 
Extended Processing Unit (1010, 1011). 



Status codes 1000 and 1001 may also indi- 
cate that the EPU is to capture or supply the 
data. 

For the Z8002, the full memory address will 
be on ADq-ADis when AS rises. For the 
Z800 1 , the offset portion of the segmented 
address will be on ADq-AD^s and the segment 
number portion will be on SNq-SNs when AS 
rises. The segment portion will also be on 
SN0-SN5 approximately one cycle before 
AD0-AD15 is valid. 
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Figure 9-3. Memory Read and Write Transaction 
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9-4. Trans- Bytes transferred to or from odd memory 

actions (address bit is 1 ) locations are always trans- 

(Continued) mitted on lines ADq-AD? (bit on ADq). Bytes 
transferred to or from even memory locations 
(address bit is 0) are always transmitted on 
lines ADs-ADis (bit on ADs). Thus, the 
memory attached to a Z8000 will look like^that 
shown inj^igure 9.4. For byte reads (B/W 
High, R/W High) the CPU uses only the byte_ 
whose address it output. For byte writes (B/W 
High, R/W Low), the memory should store only 
the byte whose address was output. During 
byte memory writes, the CPU places the same 
byte on both halves of the bus, and the proper 
byte must be selected by testing Aq. For word 
transfers, (B/W = Low), all _16 bits are cap- 
tured by the CPU (Read: R/W -:_High) or 
stored by the memory (Write: WW = Low). 
As explained more fully in Section 9.5, a 
Z800i CPU and an Extended Processing Unit 
act like a single CPU with the CPU providing 
addresses, status and timing information and 
the EPU providing or capturing data. 

9.4.3 I/O Transactions. I/O transactions move 
data to or from peripherals or CPU support 
devices (e.g., MMUs). They are generated 
during the execution of I/O instructions. 



As shown in Figure 9.5, I/O transactions are 
four clock cycles long at minimum, a nd they 
may be lengthened by the addition of WAIT 
cycles. The extra clock cycles allow for slower 
peripheral operation. 

The status lines indicate whether the access 
is to the Standard I/O (0010) or_Special I/O 
(001 1) Address Spaces. The N/S line is always 
Low, indicating system mode. The I/O address 
is found on ADq-ADis when AS rises. Since 
the I/O address is always 16 bits long, the seg- 
ment number lines are undefined on Z8001 
CPUs. For byte transfers (B/W = High) in 
Standard I/O space, addresses must be odd; 
for byte transfers in Special I/O space, 
addresses must be_even. 

Word data (B/W = Low) to or from the CPU 
is transmitted on ADq-ADis. Byte data 
(B/W = High) is transmitted on ADq-AD? for 
Standard I/O and on ADs-ADis for Special 
I/O. This allows peripheral devices or CPU 
support devices to attach to only eight of the_ 
16 ADo-ADie lines. The Read/Write line (R/W) 
indicates the direction of the_data transfer: 
peripheral-to-CPU (Read: R/W^ = High) or 
CPU-to-peripheral (Write: R/W = Low). 
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9-4. Trans- 9.4.4 EPU Transfer Transactions. These trans- 
actions actions move data between the CPU and an 
(Continued) Extended Processing Unit (EPU), thus allowing 
the CPU to transfer data to or from an EPU or 
to read or write an EPU's Status Registers. 
They are generated during the execution of 
the EPA instruction. 

EPU transfer transactions have the same 
form as memory transactions (Figure 9.3) and 
thus are three clock cycles long, unless 
extended by WAIT. No address is generated, 
and there is only one status code that can be 
used on the ST0-ST3 lines (1110). In a multiple 



EPU system, the EPU which is to participate in 
a transaction is selected implicitly, as 
described in Section 9.5, rather than by an 
address. 

The data transferred is 16-bit words 
(B/W = Low), except for transfers between the 
Flags byte of the FCW and an EPU. In this 
case, a byte of data is transferred on AD0-AD7 
(B/W = High). The Read/Write line (R/W) 
indicates the direction of the data transfer. The 
N/S line indicates either system mode (Low) or 
normal mode (High). 
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9-4. Trans- 9.4.5 Interrupt/Trap Acknowledge Trans- 
actions actions. These transactions acknowledge an 
(Continued) interrupt or trap and read a 16-bit identifier 

word from the device that generated the inter- 
rupt or trap. The transactions are generated 
automatically by the hardware when an inter- 
rupt or segment trap is detected. 

These transactions are eight clock cycles 
long at a minimum (a s shown in Figure 9 .6), 
having five automatic WAIT cycles. The WAIT 
cycles are used to give the interrupt priority 
daisy chain (or other priority resolution 
device) time to settle before the identifier word 
is read. (Consult the Z-Bus Summary for more 
information on the operation of the priority 
daisy-chain.) 

The status lines identify the type of excep- 
tion that is being acknowledged. The possibil- 
ities are Segment Trap (0100), Non-Maskable 
Interrupt (0101), Non- Vectored Interrupt 
(0110), and Vectored Interrupt (0111). No 
address is generated. The N/S line indicates 



system mode (Low), the R/W line indicates 
READ (High), and the B/W line indicates 
Word (Low). 

The only item of data transferred is the 
indentifier word, which is always 16 bits long 
and is captured from the ADp-A Dis li nes on 
the falling clock edge just before DS is 
raised High. 

As s hown i n Figure 9.6, there ar e two p laces 
where WAIT is sampled and thus a WAIT 
cycle may be inserted. The first serves to delay 
the falling edge of DS to allow the daisy chain 
a longer time to settle, and the second serves 
to delay the point at which data is read. 

9.4.6 Internal Operations and Refresh Trans- 
actions. There are two kinds of bus trans- 
actions made by the CPU that do not transfer 
data: internal operations and memory refresh. 
Both transactions look like a memory trans- 
action, except that Data Strobe remains High 
and no data is transferred. 
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Figure 9-6. Interrupt and Segment Trap Request and Acknowledge Transition. 
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9-4. Trans- For internal operation transaction (shown in 

actions Figure 9.7), the Address and Segment Number 

(Continued) hnes contain arbitrary data when the Address 
Strobe goes High. Th_e R/W hne indicates 
Read (High); the B/W hne is undefined, and 
N/S is the same as for the immediately 
preceding transaction. This transaction is initi- 
ated to maintain a minimum transaction rate 
while the CPU is doing a long internal 
operation. 

A memory refresh transaction (shown in 
Figure 9.8) is generated by the Z8000 CPU's 



refresh mechanism as described in Chapter 8 
and can come immediately after the final clock 
cycle of any other transaction. The memory 
refresh counter's 9-bit ROW field is output on 
ADg-ADg during the normal time for 
addresses. This transaction can be used to 
generate refreshes for dynamic RAMs. The 
value of NTs, R/W, and B/W is the same as for 
th e imme diately preceeding transaction. 

WAIT is not sampled during internal opera- 
tion or refresh cycles. 
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9.5 CPU and A Z8000 CPU and one or more Extended 

Extended Pro- Processing Units (EPUs) work together like a 
cessing Unit single CPU component, with the CPU pro- 
Interaction viding address, status and timing signals and 
the EPU supplying and capturing data. The 
EPU monitors the status and timing signals out- 
put by the CPU so that it will know when to 
participate in a memory or EPU transfer trans- 
action. When the EPU is to participate in a 
memory transac tion , the CPU puts its AD lines 
in 3-state while DS is Low, so that the EPU may 
use them. 

In order to know which transaction it is to 
participate in, the EPU must track the follow- 
ing sequence of events: 

■ When the CPU fetches the first word of an 
instruction (ST3-ST0 = 1101), the EPU must 
also capture the instruction returned by 
memory. If the instruction is an extended 
instruction, it will have an ID field which 
indicates (along with the second instruction) 
whether or not the EPU is to execute the 
instruction. 

■ If the instruction is to be executed by the 
EPU, the next non-refresh transaction by the 
CPU will fetch the second word of the 
instruction (ST3-ST0 = 1100). The EPU 
must also capture this word. 

■ If the instruction involves a read or write to 
memory, there will be zero or more program 
fetches by the CPU (ST3-ST0 = 1100) to 
obtain the address portion of the extended 
instruction. The next one to 16 non-refresh 
transactions by the CPU will transfer data 
between memory and the EPU (ST3-ST0 = 
1000, 1001, 1010, or lOlD^The EPU must 
supply the data (Write, ^/W Low) or cap- 
ture the data (Read, R/W High) for each 
transaction, just as if it were part of the 
CPU. In both cases, the CPU will 3-state its 



AD lines while data is being transferred 
(DS Low). EPU memory transfers are always 
word-oriented (B/W Low). 

■ If the instruction involves a transfer between 
the CPU and EPU, the next one to 16 non- 
refresh transactions by the CPU will transfer 
data between the EPU and CPU 
(ST3-ST0 = 1110). 

Note that in order to follow this sequ ence, an 
EPU will have to monitor the BUSACK line to 
verify that the transaction it is monitoring on 
the bus was generated by the CPU. It should 
also be noted that in a multiple EPU system, 
there is no indication on the bus as to which 
EPU is cooperating with the CPU at any given 
time. This must be determined by the EPUs 
from the extended instructions they capture. 

A final aspect of CPU -EPU interaction is the 
use of the CPU's STOP pin. When an EPU 
begins to execute an extended instruction, the 
CPU can continue fetching and executing 
instructions. If the CPU fetches another 
extended instruction before the first one has 
completed execu tion, the EPU must activate 
the CPU's STOP pin to stop the CPU (as 
described in Section 9.7) until the instruction 
completes execution. 

Besides determining whether or not to par- 
ticipate in the execution of an EPA instruction, 
the EPU must. determine from the first two 
instruction words 

■ Whether or not a memory access will be 
made and how many words of instruction 
will be fetched before the data is 
transferred. 

a The number of words of data to be trans- 
ferred for memory or EPU-CPU transfers. 

B The operation to be performed on its data. 



9.6 Requests There are three kinds of request signals that 

the Z-Bus supports and the Z8000 CPU par- 
ticipates in. These are 

■ Interrupt/Trap requests, which another 
device initiates and the CPU accepts and 
acknowledges. 

■ Bus requests, which another potential bus 
master initiates and the CPU accepts and 
acknowledges. 

■ Resource requests, which any device 
capable of implementing the request pro- 
tocol (usually the CPU) can request. No 
component has control of the resource by 
default. 



The CPU supports an additional request 
beyond those of the Z-Bus: 

B Stop request, which another device initiates 
and the CPU accepts. 

When a request is made, it is answered 
according to its type: for interrupt/trap 
requests, an interrupt/trap acknowledge trans- 
action is initiated (Section 9.4.4); for bus 
requests, an acknowledge signal is sent (Sec- 
tions 9.6.2 and 9.6.3); for Stop request, the 
CPU enters the Stop/Refresh state. In all cases 
except Stop, the Z-Bus provides for a daisy- 
chain priority mechanism to arbitrate between 
simultaneous requests. 
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9-6. Requests 9.6.1 Interrupt/Trap Request. The Z8000 CPU 
(Continued) supports three interrupts and one external trap 
(segment trap) as show n in Figure 9.6. The 
Interrupt Request line (INT) of a device that is 
capable of generating an interrupt may be tie d 
to an y of the three Z8000 interrupt pins (NMI, 
NVI, VI). Several devices can be connected to 
one pin, the devices arranged in a priority 
daisy chain (see the Z-Bus Summary) . The seg- 
ment trap pin (SEGT) is activated by the 
memory management hardware. The CPU uses 
the same protocol for handling requests on any 
of these pins. Here is the sequence of events 
that is followed: 

■ Any High-to-Low transition on the NMI 
input is asynchronously edge- detected, and 
the internal NMI latch is set. At the begin- 
ning of the last clock cycle in the last 
machine cycle o f any instruction, the VI, 
NVI, and SEGT inputs are s ampl ed along 
with the state of the internal NMI latch. 

■ If an interrupt or trap is detected, the sub- 
sequent initial instruction fetch cycle is 
exercised, but aborted. 



■ The next machine cycle is the interrupt 
acknowledge transaction (see Section 9.4.4) 
that results in an identifier word from the 
highest-priority interrupting device being 
read off the AD lines. 

■ This word, along with the program status 
information, is stored on the system stack, 
and new status information is loaded (see 
Chapter 7). 

For more information about the system-level 
aspects of the interrupt structure, consult the 
Z-Bus Summary. 

9.6.2 Bus Request. To generate transactions 
on the bus, a potential bus master (such as the 
DMA Controller) must gain control of the bus 
by making a bus request (shown in Figure 
9.9). A bus request is initiated by pulling 
BUSREQ Lo w. Severa l bus requesters may be 
wired to the BUSREQ pin; priorities are 
resolved externally to the CPU, usually by a 
priority daisy chain (see the Z-Bus Summary) . 

The asynchronous BUSREQ signal generates 
an internal BUSREQ, which is synchronous. If 
the external BUSREQ is Low at the beginning 




v/ 



MREQ, DS, ' 
_ ST0-ST3, 
B/W, R/W, N/S , 



\ 



/ 



J- 



< 



, SAME AS PREVIOUS CYCLE 



)C1 



Figure 9-9. Bus Request/ Acknowledge Timing 
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9-6. Requests of any ma chine cycle, the internal 
(Continued) BUSREQ w ill cause the bus acknowledge line 
(BUSACK) to be asserted after the current 
machine cycle is completed. The CPU then 
enters Bus-Disconnect state and gives up con- 
trol of the bus. All CPU Output pins, except 
BUSREQ and MO, are 3-stated. 

The CPU regains control of the bus two 
clock cycles after BUSREQ rises. Any device 
desiring control of the bu s must wait at least 
two cycles after BUSREQ has risen before 
pulling it down again. 

9.6.3 Resource Request. The CPU generates 
resource requests by executing the Multi-Micro 
Request (MREQ) instruction. The CPU tests the 
availability of the shared resource by examin- 
ing MI. If MI is High, the resource is 
available, othe rwise the CPU must try again 
later. Th e M O pin is used to make the resource 
request. MO is pulled Low, then, after a delay 



for arbitration of priority, MI is tested again. If 
it is Low, the CPU has control of the resource; 
if it is still High, the request was not granted. 
In the case of fail ure, MO must be deactivated. 
But if successful, MO must be kept active until 
the CPU is ready to release the resource 
whereupon MO is deactivated by an MRES 
instruction. 

The Z-Bus Summary describes an arbitration 
scheme that is implemented with a resource 
request daisy chain. 

9.6. 4 Stop Request. As shown in Figure 9-10, 
the STOP pin is normally sampled on the fall- 
ing clock edge immediately preced ing an ini- 
tial instruction fetch cycle. If STOP is found 
Low, the CPU enters Stop/Refresh state and a 
stream of memory refresh cycles is inserted 
after the third clock cycle in the instruction 
fetch. The ROW field in the Refresh Counter is 
incremented by two after every refresh cycle. 
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Figure 9-10. Stop Timing 
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9-6. Requests When STOP is found High again, the next 
(Continued) refresh cycle is completed, then the original 
instruction continues. 

If the EPA bit in the FCW is set ( indicating 
an EPU is in the system), the STOP line is also 
sampled on the on the falling clock edge 
immediately preceding the second word of an 



instruction fetch — if the first word indicates an 
extended instruction. Thus, the STOP line may 
be used by an EPU to deactivate the CPU 
whenever the CPU fetches an extended 
instruction before the EPU has fin ished pro- 
cessing an earlier one. The STOP line may 
also be used to externally single-step the CPU. 



9.7 Reset A hardware reset puts the Z8000 in a known 

state and initializes selected control registers 
of the CPU to system specifiable values (as 
described in Section 7.4). A rese t will be gin at 
the end of any clock cycle, if the RESET line 
is Low. 

A system reset overrides all other operations 
of the chip, including interrupts, traps, bus 
reguests and stop reguests. A reset should be 
used to initialize a system as part of the power- 
up seguence. 

Within five clock cycles of the RESET 



line becoming lo w (F i gure 9. 1 1), ADp- ADis 
are 3-stated; AS, DS, MREQ, BUSACK, 
Mq, and ST0-ST3 are forced ffigh; SNq-SNs 
are forced Low. The R/W, B/W and N/S lines 
are undefined. Reset must be held Low at least 
five clo ck cycl es. 

After RESET has returned High for three 
clock cycles, consecutive memory-read trans- 
actions are executed in the system mode to ini- 
tialize the Program Status Registers. These cor- 
respond to the memory accesses described in 
Section 7.4 
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Figure 9-11. Reset Timing 
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Composite 
AC Timing 
Diagram 
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This composite timing dia- 
gram does not show actual 
timing sequences. Refer to 
this diagram only for the 
detailed timing relationships 
of individual edges. Use the 
preceding illustrations as an 
explanation of the various 
timing sequences. 
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Timing measurements are 
made at the following 
voltages; 

High Low 

Clock 4.0V 0.8V 

Output 2.0V 0.8V 

Input 2.0V 0.8V 

Float AV ±0.5V 
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AC 






Z8001/Z8002 


Z8001A/Z8002A 


Character- Number 


Symbol 


Parameter 


Min 


Max 


Min 


Max 


istics 






(ns) 


(ns) 


(ns) 


(ns) 


1 


TcC 


Clock Cycle Time 


250 


2000 


165 


2000 


2 


TwCh 


Clock Width (High) 


105 


2000 


70 


2000 


3 


TwCl 


Clock Width (Low) 


105 


2000 


70 


2000 


4 


TfC 


Clock Fall Time 




20 




10 


5 


IrC 


Clock hise iime 








10 


6 


TdC(SNv) 


Clock t to Segment Number Valid (50 pF load) 




130 




110 


7 


TdC(SNn) 


Clock t to Segment Number Not Valid 


20 




10 




8 


TdC(B2) 


Clock t to Bus Float 




65 




55 


9 


TdC(A) 


Clock t to Address Valid 




100 




75 


— lo- 












55- 










ll 


TdA(DI) 


Address Valid to Data In Required Valid 




455* 




305* 


12 


TsDl(C) 


Data In to Clock 1 Setup Time 


50 




20 




13 


TdDS(A) 


DS t to Address Active 


80* 




40* 




14 
— 15 — 


TdC(DO) 


Clock t to Data Out Valid 




100 


- 


75 













16 


TdDO(DS) 


Data Out Valid to DS t Delay 


295* 




195* 




17 


TdAMR 


Address Valid to MREQ 1 Delay 


55* 




35* 




18 


TdC(MR) 


Clock 1 to MREQ 1 Delay 




80 




70 


19 
— 20 — 


TwMRh 


MREQ Width (High) 


210* 




135* 
















21 


TdDO(DSW) 


Data Out Valid to DS 1 (Write) Delay 


55* 




35* 




22 


TdMR(DI) 


MREQ 1 to Data In Required Valid 




350* 




225* 


23 


TdC(MR) 


Clock 1 MREQ 1 Delay 




80 




60 


24 
— 25 — 


TdC(ASf) 


Clock t to AS 1 Delay 




80 


— 35*- 


60 




Addi'ess Vdlid Lo Ao 1 Delay 


DO 






26 


TdC(ASr) 


Clock 1 to AS t Delay 




90 




80 


27 


TdAS(DI) 


AS t to Data In Required Valid 




340* 




215* 


28 


TdDS(AS) 


DS t to AS 1 Delay 


70* 




35* 




29 


TwAS 


AS Width (Low) 


85* 




55* 




— 30 — 


- TdAS(A) 


— AS t to Address Not Active Delay 


— 60*- 




— 30*- 





31 


TdAz(DSR) 


Address Float to D5 (Read) 1 Delay 












32 


TdAS(DSR) 


AS f to DS (Read) 1 Delay 


70* 




35* 




33 


TdDSR(DI) 


DS (Read) 1 to Data In Required Valid 




185* 




130* 


34 


TdC(DSr) 


Clock 1 to DS t Delay 




70 




65 


— 35 — 


-TdDS(DO) — 


- DS t to Data Out and STATUS Not Valid 


— 75*- 




45*- 




36 


TdA(DSR) 


Address Valid to DS (Read) 1 Delay 


180* 




110* 




37 


TdC(DSR) 


Clock t to DS (Read) 1 Delay 




120 




85 


38 


TwDSR 


DS (Read) Width (Low) 


275* 




185* 




39 
— 40 — 


TdC(DSW) 


Clock 1 to DS (Write) J Delay 




95 




80 


1 wDbW 


Do (Wnle) WidLli (Low) 










41 


TdDSI(DI) 


DS (Input) 1 to Data In Required Valid 




320* 




200* 


42 


TdC(DSf) 


Clock 1 to DS (I/O) 1 Delay 




120 




100 


43 


TwDS 


DS (I/O) Width (Low) 


410* 




255* 




44 


TdAS(DSA) 


AS t to DS (Acknowledge) 1 Delay 


1065* 




690* 




— 45 — 


- TdC(DSA) 


-Clock t to DS (Acknowledge) 1 Delay 




— 120 — 




85- 


46 


TdDSA(DI) 


DS (Ack.) 1 to Data In Required Delay 




435* 




295* 


47 


TdC(S) 


Clock t to Status Valid Delay 




110 




85 


48 


TdS(AS) 


Status Valid to AS t Delay 


50* 




30* 




49 
— 50 — 


TsR(C) 


RESET to Clock t Setup Time 


180 
0- 




70 
0- 












51 


TwNMI 


NMI Width (Low) 


100 




70 




52 


TsNMI(C) 


NMI to Clock t Setup Time 


140 




70 




53 


TsVI(C) 


VI, NVI to Clock t Setup Time 


110 




50 




54 


ThVI(C) 


VI, NVI to Clock t Hold Time 












— 55 — 


- TsSGT(C) 


— SEGT to Clock t Setup Time 


70- 




55- 




56 


ThSGT(C) 


SEGT to Clock t Hold Time 












57 


TsM;(C) 


Mj to Clock t Setup Time 


180 




110 




58 


ThMi(C) 


Mj to Clock t Hold Time 












59 


TdC(Mo) 


Clock t to Mo Delay 




120 




85 


— 60 — 


■ TsSTP(C) 


- STOP to Clock i Setup Time -. 


— 140- 




70 




61 


ThSTP(C) 


STOP to Clock 1 Hold Time 












62 


TsWT(C) 


WAIT to Clock i Setup Time 


50 




30 




63 


ThWT(C) 


WAIT to Clock 1 Hold Time 


10 




10 




64 


TsBRQ(C) 


BUSREQ to Clock t Setup Time 


90 




80 




— 65 — 


■ ThBRQ(C) 


- BUSREQ to Clock t Hold Time 


10 — 




10- 





66 


TdC(BAKr) 


Clock t to BUSACK t Delay 




100 




75 


67 


TdC(BAKf) 


Clock t to BUSACK I Delay 




100 




75 



* Clock-cycle-time-dependent characteristics. 
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Clock- 
Cycle-Time- 
Dependent 
Characteristics 



Number 



Symbol 



Z8001/Z8002 
Equation 



Z8001A/Z8002A 
Equation 



11 
13 
16 
17 

•19- 
20 
21 
22 
25 

■27- 
28 
29 
30 
32 

■33- 
35 
36 
38 
40 

■41- 
43 
44 
46 
48 



TdA(DI) 
TdDS(C) 
TdDO(DS) 
TdA(MR) 
■ TwMRh — 



TdMR(A) 

TdDO(DSW) 

TdMR(Dl) 

TdA(AS) 
■TdAS(DI) 

TdDS(AS) 

TwAS 

TdAS(A) 

TdAS(DSR) 
■TdDSR(DI)— 

TdDS(DO) 

TdA(DSR) 

TwDSR 

TwDSW 
■TdDSI(DI) — 

TwDS 

TdAS(DSA) 

TdDSA(DI) 

TdS{AS) 



2TcC + TwCh - 150 ns 
TwCl - 25 ns 
TcC + TwCh - 60 ns 
TwCh - 50 ns 

■ TcC - 40 ns 

T'wCl - 35 ns 

T'wCh - 50 ns 
2TcC - 150 ns 
TwCh - 50 ns 

■ 2TcC - 160 ns 

T'wCl - 35 ns 

T'wCh - 20 ns 
TwCl - 45 ns 
TwCl - 35 ns 

■ TcC + TwCh - 170 ns— 
TwCl - 30 ns 

TcC - 70 ns 

TcC + TwCh - 80 ns 

TcC - 65 ns 

' 2TcC - 180 ns 

2TcC - 90 ns 
4TcC + TwCl - 40 ns 
2TcC + TwCh - 170 ns 
TwCh - 55 ns 



2TcC + TwCh - 95 ns 
TWCl - 30 ns 
TcC + TwCh - 40 ns 
TwCh - 35 ns 
■TcC - 30 ns 



TwCl - 35 ns 

TwCh - 35 ns 

2TcC - 105 ns 

TwCh - 35 ns 
' 2TcC - 115 ns 

TwCl - 35 ns 

TwCh - 15 ns 

TwCl - 40 ns 

TwCl - 35 ns 
■ TcC + TwCh - 105 ns- 

TwCl - 25 ns 

TcC - 55 ns 

TcC + TwCh - 50 ns 

TcC - 55 ns 
■2TcC - 130 ns 

2TcC - 75 ns 

4TcC + TwCl - 40 ns 



2TcC + TwCh 
TwCh - 40 ns 



105 ns 
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Absolute Voltages on all inputs and outputs 

Maximum with respect to GND -0.3 V to + 7.0 V 

Ratings Operating Ambient 

Temperature 0°Cto +70°C 

Storage Temperature -65°C to +150°C 



Stresses greater than those hsted under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



Standard 

Test 

Conditions 



The characteristics below apply for the 
following standard test conditions, unless 
otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 

■ +4.75 V < V^^ < +5.25 V 



GND = V 
0°C < T„ < 



cc 



+ 70°C 



All ac parameters assume a load capacitance of 100 pF max, ex- 
cept for parameter 6 (50 pF max). Timing references between two 
output signals assume a load difference of 50 pF max. 



DC 

Character- 
istics 



Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


Vcc-0.4 


Vcc + 0.3 


V 


Driven by External Clock 
Generator 


VCL 


Clock Input Lov^ Voltage 


-0.3 


0.45 


V 


Driven by External Clock 
Generator 


VlH 


Input High Voltage 


2.0 


Vcc + 0.3 


V 




VlHRESET 


High Voltage on Reset Pin 


2.4 


Vcc to 0.3 


V 




ViL 


Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Iqh = -250 ^,A 


Vol 


Output Low? Voltage 




0.4 


V 


lOL = +2.0,.A 


IlL 


Input Leakage 




±10 


/^A 


0.4 < ViN < -1-2.4 V 


IjLSEGT 


Input Leakage on Segt Pin 


-100 


100 


M 




lOL 


Output Leakage 




±10 


^A 


0.4 < ViN < +2.4 V 



Ice 



Vcc Supply Current 



300 



mA 



Ordering 
Information 



Part Number 



Temperature 
Range 



Number 
of Pins 



Package 



Description 



Z8001 CPU 
Z8002 CPU 



0°C to -h70°C 
0°C to -f-70°C 



40 



Ceramic Segmented 16-Bit Microprocessor 

Ceramic Non-Segmented 16-Bit Microprocessor 
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Package 
Dimensions 













0.5 


98 


) 












PIN 1 


^O 




IDENTIFICATION 














I 



J 



0.040 

_*.007 

-.002 

TYP 



40-Pin Ceramic Package (Z8002) 













0.598 
MAX 


) 














PIN1 


"'O 




VTION 


^ 











_0.530 
MAX 



0.010 

±.010 — 
TYP I 











2.425 




0.185 0.095 






MAX 
1. 0-530 ., 


0.040 

^ ^*.007 

-.002 

TYP 


J 


I 


MAX 










y 


^ 


lf}fH 


BOTH ENDS 


1 1 

I L 0.100 
~^ ' ±.010 TYP 


¥iM¥/ 


i 


' 




1 




0.125 
MIN 


-* 




1 0.050 
' ±.025 


1 1 0.018 
~^' ±.003 TYP 



0.060 
0.020 



48-Pin Ceramic Package (Z8001) 
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B 



■ ■ 



F^^l 



T^-il 



Zilog 



Z8010 MMU 
Memory 
Management Unit 



Zilog 



Product 
Brief 



Preliminary- 



August 1979 



Features ■ Dynamic segment relocation makes software 

addresses independent of physical memory 
addresses. 

■ Sophisticated access validation protects 
memory areas from unauthorized or unin- 
tentional access. 

■ MMU architecture supports multiprogram- 
ming systems. 



Sixty-four variable-sized segments from 256 
to 64K bytes can be managed within a total 
physical address space of 16M bytes; all 64 
segments are randomly accessible. 

Multiple MMUs can support several transla- 
tion tables for each of the six Z8001 address 
spaces. 



Description Declining memory costs coupled with the 

increasing power of microprocessors has 
accelerated the use of high-level languages, 
sophisticated operating systems, complex pro- 
grams and large data bases in micromputer 
systems. The Z8001 microprocessor CPU sup- 
ports these trends with an eight megabyte 
direct address space as well as a rich and 
powerful instruction set. The Z8010 Memory 
Management Unit (MMU) provides flexible and 



efficient support for this large address space 
by offering dynamic segment relocation as well 
as numerous memory- protection features. 

The primary memory of a computer is one 
of its major resources. As such, the manage- 
ment of this resource becomes a major con- 
cern as demands on it increase. These 
demands arise from multiple users (or multiple 
tasks within a dedicated application), the need 
to increase system integrity by limiting access 
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DATA BUS 



SEGMENT / 
KUMBER S 



SEGMENT 
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DMA/SEGMENT 



CHIP SELECT 
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csL 


1 


48 


3 n;s 
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2 


47 


J WW 


SEGT [; 
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46 
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SUP C 
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45 


jDS 


RESET C 


5 


44 


JSTo 


A23[: 


6 


43 


ISJ, 


A22C 


7 


42 


J ST, 


A2,[: 


S 


41 


3ST3 


A20C 


9 


40 


JaDs 


A,,C 


10 


39 


J ADg 


+ 5V C 


11 Z8010 38 


3 AD,o 


A„C 


12 MMU 37 


3 AD,, 


A,7[: 


13 


36 


m CLK 


AieC 


14 


35 


^ GND 


A-sC 


15 


34 


3 AD,2 


AuC 


16 


33 


3 AD,3 


AnL 


17 


32 


Dad,, 


AnL 


18 


31 


HaDis 


A„L 


19 


30 


3SN„ 


Aiot 


20 


29 


JSN, 


A,i: 


21 


28 


JSN2 


AaC 


22 


27 


3SN3 


DECOUPLE [;; 


23 


26 


DSN4 


SNeL 


24 


25 


ZJSNs 



I- 5 V GND CLK RESET DECOUPLE 



Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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Description to various portions of the memory, and from 
(Continued) the need to structure large, complex programs 
and systems. 

Multiple tasks (or users) of a system that 
can reside anywhere in memory are called 
relocatable. Generally, systems in which all 
tasks are relocatable offer far greater flexibility 
in responding to changing system environ- 
ments. Another aspect of multiple-task envi- 
ronments is sharing: separate tasks can 
execute the same program on different data, or 
several tasks may execute different programs 
using the same data. 

Unfortunately, a problem that arises in 
multiple-task systems is that of system integrity. 
Tasks must be protected from unwanted inter- 
actions with other tasks; user tasks must be 
prohibited from performing operating system 
functions;, and user tasks must also be pro- 
tected from themselves so they cannot overflow 
the areas allotted to them. 

In addition to these considerations, support 
for the design and implementation of large, 
complex programs and systems is itself an 
important consideration. Modern trends are 
toward the partitioning of a complex task into 
small, simple, self-contained subtasks that have 
well-defined interfaces. Because these subtasks 
interact with each other, communication 
between them must be carefully controlled. 
Memory- management systems can offer effec- 
tive solutions for implementing large systems 
modularly designed. 

The Z8010 Memory Management Unit sup- 
ports multiple-process and large modular soft- 
ware systems with dynamic segment relocation. 
Futhermore, it enhances system integrity with 



a powerful set of memory protection features. 

Relocation. Dynamic segment relocation 
makes user software addresses independent of 
the physical memory addresses, thereby free- 
ing the user from specifying where information 
is actually located in the physical memory and 
providing a flexible, efficient method for sup- 
porting multi-programming systems. 

The Z-MMU uses a translation table to 
transform the 23-bit logical addresses from the 
Z8001 CPU into 24-bit addresses for the 
physical memory. Memory segments are 
variable in size from 256 bytes to 64K, in 
increments of 256 bytes. Pairs of Z-MMUs sup- 
port the 128 segment numbers available for the 
various Z8001 CPU address spaces. Within an 
address space, any number of Z-MMUs can be 
used to accommodate multiple translation 
tables for system and normal operating modes, 
or to support more sophisticated memory- 
management systems. 

System Integrity. Z-MMU memory-protection 
features safeguard memory areas from 
unauthorized or unintended access by 
associating special access restrictions with 
each segment. A segment is assigned a "per- 
sonality" consisting of several attributes when 
it is initially entered into the Z-MMU. When a 
memory reference is made, these attributes are 
checked against the status information sup- 
plied by the Z8001 CPU. If a mismatch occurs, 
a trap is generated and the CPU is inter- 
rupted. The CPU can then check the status 
registers of the MMU to determine the cause 
and take appropriate action to correct the prob- 
lem. 
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Figure 3. The MMU in a Z8000 System 
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Features ■ Multiplexed address/data bus, shared by 

I/O and memory. 

■ Peripherals may be asynchronous. 

■ Up to 24-bit memory address, 16-bit I/O. 

■ 8 or 16 data bits. 



Daisy-chained bus request. 
Daisy-chained resource request. 
Vectored or non vectored interrupts. 
Separate memory and I/O address space. 



Description The Z-bus is a shared bus that links the com- 

ponents of the Z8000 family. A bus user can be 
any device that can generate bus transactions. 
Five different types of transactions can be 
passed on the Z-bus to serve the basic needs of 
I/O and memory structures in a distributed- 
processing environment. The five types are: 

■ Memory access 

■ I/O transfer 

■ Interrupt 

■ Bus request 

■ Resource request 

Direct addressing of the internal registers of 
peripherals is facilitated by the use of 
multiplexed address and data lines. (See 
Figure 1.) The Z-bus is asynchronous, so 
peripherals' clocks need not be synchronized 
with the CPU clock, which is therefore not 
transmitted on the bus directly. The signals 
(strobes, acknowledges, etc.) generated in the 
course of any transaction provide all necessary 
timing information. 

Memory Access. Status signals issued by the 
CPU distinguish memory transactions from 
others and select the address space to be 
access ed. Slow memory devices may assert the 
WAIT signal toprolong the transaction. 
Extended addresses may be used with the 
segmented Z8001 CPU and the Z8010 MMU. 
Other status signals define direction (R/W), 
Normal/System (N/'S), Byte/Word (B/W), and 
the various address spaces. 
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Figure 1. Z-Bus Signals 
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Figure 2. Interrupt Connections 



I/O Transfer. The status line I/O reference 
distinguishes I/O transactions from others. The 
16-bit multiplexed bus is use d for address and 
data (with out ext ension), and AS, DS, R/W, 
B/W, and WAIT are used in a similar way. 

Direct addressing of the internal registers of 
peripherals is facilitated by the use of 
multiplexed address and data lines. (See 
Figure 1.) The Z-bus is asynchronous, so 
peripherals' clocks need not be synchronized 
with the CPU clock, which is therefore not 
transmitted on the bus directly. The signals 
(strobes, acknowledges, etc.) generated in the 
course of any transaction provide all necessary 
timing information. 

Interrupt. The Z-bus interrupt scheme is an 
interrupt-under-service priority daisy chain 
that requires no separate priority controller. 
Interrupt requests are all tied directly to the 
iNT pin of the CPU. (See Figure 2.) Physical 
position along the lEI/IEO daisy chain deter- 
mines the priority assigned to any given 
peripheral. Up on receip t of an INT signal, the 
CPU issues an INTACK. (See Figure 3.) This 
temporarily inhibits further interrupt requests, 
while all devices that have init iated interrupt 
requests prior to that INTACK drop their lEO 
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outputs. (Multiple INTs might occur 
simultaneously.) The highest-priority lEO has 
the effect of removing lEI inputs from all 
devices beyond it on the same daisy chain, 
thereby preventing them from requesting inter- 
rupts further until their lEI inputs are restored. 
Three W ait cycles aft er the leading edge of 
INTACK (or more, if WAIT has been asserted 
by the highest-priority device requesting ser- 
vice), to allow the chain to settle, a DS from 
the CPU stimulates the one highest-priority re- 
questing peripheral to place its vector on the 
bus. Two (or more) additional Wait cycles 
later, the service routine is invoked, and 
INTACK is returned high. At this time, all re- 
questers of higher priority than the one being 
serviced (those whose lEI lines are still high) 
are enabled, and may generate new interrupt 
requests. Once a peripheral has been serviced 
it unmasks the daisy chain so lower-priority in- 
terrupts can be generated. 

Bus Request. The bus request is used to 
transfer control o f the Z-b us for memory or I/O 
transactions. The BUSRQ in put li ne to the 
Z-bus CPU, the wired-OR of BRQ outputs from 
all requ esters, initiates a bus request. The 
BUSAK output line from the CP U is da isy- 
chained through BAI inputs and BAO outputs 
of all requesters in order of priority, to grant 
use o f the bus to the first requester whose 
BAO is held high at that time. 

Resource Request. The resource request 
chain is used to share a resource among 
several Z-bus CPUs, none of which is default 
master of that resource. The resource-request 
protocol is similar to that of the bus request, 
except for an added status line that inhibits all 
requesters from issuing requests any time the 
resource is busy. The acknowledge daisy- chain 
resolves contention in the event of simul- 
taneous requests. 



Figure 3. Interrupt Acknowledge Timing 
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Features ■ Complete slave microcomputer, for 

distributed-processing Z-Bus use. 

■ Unmatched power of Z8 architecture, 
instruction set. 

■ Three programmable I/O ports, two with 
2-wire handshake, or any combination of 
data and control lines. 

■ Six levels of priority interrupts to Z-UPC. 



Two programmable 8-bit counter/timers with 
6-bit prescalers. 

256 byte register file, accessible by both 
master CPU and Z-UPC, as allocated by 
Z-UPC program. 

2K bytes of on-chip program ROM for effi- 
ciency, versatility. 



Description The Z-UPC Universal Peripheral Controller 

is a distributed microcomputer that performs 
the three basic interfacing functions needed to 
interface a CPU with peripherals: device con- 
trol by ROM-resident internal software, data 
manipulation, such as reformatting or 
arithmetic, and data buffering in internal 
registers. 

The Z-UPC is similar to the Z8 microcom- 
puter and uses the Z8 instruction set. Under 



program control, its three 8- line I/O ports can 
be tailored to the needs of its user. Perma- 
nently configured as a single-chip controller 
with 2K bytes of internal ROM, the Z-UPC 
executes instructions in 2.2 fis average using a 
4-MHz clock source. Its register file contains 
256 bytes, of which 234 are general-purpose 
registers, 19 are status and control registers, 
and three are port registers. 
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Description The Z-UPC Universal Peripheral Controller 

(Continued) is an intelligent device that generates all the 
control signals peripheral devices need. 
Because it does off-line arithmetic, translates 
data before transmitting, and, buffers data, the 
Z-UPC unburdens the master CPU, thereby 
increasing the overall speed and efficiency of 
the system in which it resides. 

Based upon the Z8 microcomputer architec- 
ture, the Z-UPC offers fast execution time, effi- 
cient use of memory, and sophisticated inter- 
rupt, I/O, and bit manipulation. Its powerful 
and extensive instruction types, combined with 
its efficient internal register addressing 
scheme, not only speeds program execution, 
but also efficiently packs program into the on- 
chip ROM. 

A unigue characteristic of the Z-UPC is its 
register file, which contains I/O port and con- 
trol registers that can be accessed both by the 
Z-UPC program and by its associated master 
CPU. This results in byte efficiency, program- 
ming efficiency, and address space efficiency 
because Z-UPC instructions can operate direct- 
ly on I/O data without moving it to and from 
an accumulator. It also allows the Z-UPC user 
to allocate as data buffer between the CPU and 
the peripheral all register space not in use as 



accumulators, address pointers, index regis- 
ters, or stack. Registers not used as buffer are 
protected against CPU access. 

The register file is divided into 16 groups of 
16 working registers each. A register pointer 
allows fast, short-format instructions to access 
any one of these groups guickly, resulting in 
fast and easy task switching. Two-way com-: 
munication between the master CPU and the 
register file is facilitated by another pointer 
that positions 16 interface registers anywhere 
within the register file.' These registers are 
accessed directly by both the master CPU and 
the slave Z-UPC. Four more registers, similarly 
accessed, convey control and status informa- 
tion. 

All of Z-Bus's daisy-chained priority inter- 
rupt system can be implemented in the Z-UPC 
under software control, or the Z-UPC can be 
programmed to function in a polled 
environment. In all, the Z-UPC has 24 pins 
that can be dedicated to I/O functions. 
Grouped logically into three 8-line ports, they 
can be programmed in many combinations of 
inputs, outputs, and bidirectional lines, with or 
without handshake and with push-pull or open- 
drain outputs. 
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Figure 3. Z-UPC Functional Block Diagram 
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Features ■ Two independent 8-bit double-buffered 

bidirectional I/O ports plus a special- 
purpose 4-bit I/O port. 

■ Four handshake modes including 3-wire. 

■ Request/Wait line for high speed data 
transfer. 



Three independent 16-bit counters. 

All registers read/write and directly 
addressable. 

Flexible pattern recognition logic, program- 
mable as 16-input interrupt controller. 



Description The Z8036 CIO Counter/timer and Parallel 

I/O element is a general-purpose peripheral 
circuit that satisfies most counter/timer and 
parallel I/O needs encountered in system 
designs. This versatile device contains three 
I/O ports and three counter/timers. Many pro- 
grammable options tailor its configuration to 
specific applications. The use of the device is 
simplified by making all internal registers 
(command, status, and data) readable and 
(except for status bits) writable. Also, each 
register is given its own unique address so it 
can be accessed directly — no special sequen- 
tial operations are required. The Z-CIO is 
directly Z-Bus compatible. 

Either 8-bit I/O port can be a handshake 



byte port or a bit port. In the bit mode, data 
direction is programmable bit by bit. In the 
handshake mode, the ports can be input, out- 
put, or bidirectional, and they may be linked 
to form a 16-bit port. The four handshake 
modes include 3-wire (like IEEE-488), 
interlocked (for interfacing to a Z-UPC, Z-FIO 
or another Z-CIO), strobed, and pulsed. The 
pulsed mode connects one counter/timer with 
the handshake logic for interfacing a 
mechanical device such as a printer. The 4-bit 
port provides handshake controls, special 
controls (Wait/Reguest) or general-purpose I/O. 

The counter/timer section contains three 
16-bit counters, two of which can be software- 
configured as a 32-bit counter/timer. Up to 
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Description four I/O lines for each counter are available 
(Continued) for direct external control and status informa- 
tion. All counters have a programmable output 
duty cycle, continuous or single-cycle oper- 
ation, and the counting process can be pro- 
grammed to be either retriggered or nonretrig- 
gered. 

Figure 3 shows how the Z-CIO is used. The 
two general purpose 8-bit ports are similar. 
They can be programmed as handshake 
driven, double-buffered ports (input, output, 
or bidirectional) or as control ports in which 
the direction of each bit is individually pro- 
grammable. Port B can also be specified to 
provide external access for two of the counter/ 
timers. Each port includes pattern recognition 
logic allowing interrupt generation when a 
specified pattern is detected. The pattern 
recognition logic can be programmed so that 
the port functions like a priority interrupt con- 
troller. 

To control these capabilities, each port con- 
tains 13 registers. Three of these, the input, 
output, and buffer registers, are data path 
registers. Two others, the mode specification 
and handshake specification registers, define 
the mode of the port and specify what hand-, 
shake to use, if any. The reference pattern for 
the pattern recognition logic is defined in 
three registers, the pattern polarity, pattern 
transition, and pattern mask registers. The 
detailed characteristics of each bit path (for 
example, the direction of data flow, or whether 
a path is inverting or noninverting) are pro- 
grammed using the data path polarity, data 
direction, and special I/O control registers. 
The primary control and status bits are 
grouped in a single register so that after the 
ports are configured initially, only this register 



need be accessed often. One register contains 
the interrupt vector associated with each port. 
To facilitate initialization, the port logic is 
designed so that if a capability of the port is 
not required the registers associated with that 
capability are ignored and need not be pro- 
grammed. 

The function of port C depends upon the 
roles of ports A and B. Port C provides hand- 
shake lines for the other two when required. 
Any bits of port C not so used can be used as 
I/O lines or as external access to the third 
counter/timer. 

Besides the data input and output registers, 
three registers are needed. These specify the 
details of each bit path: data path polarity, 
data direction, and special I/O control. 

The three counter/timers are all identical. 
Each is composed of a 16-bit down-counter, a 
16-bit time constant register (which holds the 
value loaded into the down- counter), a 16-bit 
current count register (used to read the con- 
tents of the down- counter), and two 8- bit 
registers for control and status (the mode 
select and control registers). All three share a 
common vector register. 

Each counter/timer can be programmed as 
either counter or timer. Up to four port I/O 
lines can be designated as external access 
lines for it. The lines are: Counter Input, Gate 
Input, Trigger Input, and Counter/Timer Out- 
put. Three different counter/timer output duty 
cycles are available: pulse, one-shot, or 
square wave. The operation of the counter/ 
timer can be specified to be either single cycle 
or continuous. The counting sequence may be 
retriggered or nonretriggered, under program 
control. 



1 



^ 



CONTROL 

AND 

STATUS 



CONTROL 
STATUS 



Figure 3. Functional Block Diagram 



03-8050-02 



Z8030 sec Serial 

Communications 

Controller 



Zilog 



Product 
Brief 



Preliminary- 



February 1980 



Features ■ Two independent, to IM bit per second, 

full-duplex channels, each with its own 
quartz oscillator, baud-rate generator, and 
digital phase-locked loop for clock 
recovery. 

■ Multi-protocol operation under program 
control. 

■ Programmable for NRZ, NRZI, or FM 
coding. 

■ Asynchronous mode with 5 to 8 bits and 1 , 
l!/2, or 2 stop bits per character, program- 
mable clock factor, break detection and 
generation, and parity, overrun, and fram- 



ing error detection. 

Bisynchronous mode with internal or exter- 
nal character synchronization on one or two 
sync characters and CRC generation and 
checking with CRC- 16 or CRC-CCITT 
preset to either Is or Os. 

SDLC/HDLC mode with comprehensive 
frame-level control, automatic zero insertion 
and deletion, I-field residue handling, abort 
generation and detection, CRC generation 
and checking, and SDLC loop mode 
operation. 

Local loopback and auto-echo modes. 



Description The Z-SCC Serial Communication Controller 

is a dual-channel, multi-protocol data com- 
munication peripheral for Z-Bus use. It is 
software-configured to satisfy a wide variety of 
serial communication applications. Its basic 
function is serial-to-parallel and parallel-to- 
serial conversion. However, the Z-SCC also 
contains a repertoire of new, sophisticated 
internal functions that minimize the need for 



external random logic on the circuit card. 

The Z-SCC handles asynchronous formats, 
synchronous byte-oriented protocols such as 
IBM Bisync, and synchronous bit-oriented pro- 
tocols such as HDLC and IBM SDLC. This ver- 
satile device also supports virtually any other 
serial data transfer application (cassette or 
diskette interface, for example). 

The device can generate and check CRC 
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Description codes in any synchronous mode and can be 
(Continued) programmed to check data integrity in various 
modes. It also has facihties for modem controls 
in both channels. In applications where these 
controls are not needed, the modem controls 
can be used for general-purpose I/O. 

As is standard among Zilog peripheral com- 
ponents, the Z-Bus daisy-chain interrupt 
heirarchy is supported. 

The Z-SCC contains the necessary multi- 
plexed address/data bus interface with strobe 
and chip select lines to function as a Z-Bus 
peripheral. It includes internal control and 
interrupt logic, two full-duplex channels and 
two baud- rate generators. Associated with 
each channel are several read and write 
registers for mode control as well as the logic 
necessary to interface to modems or other 
external devices. 



The read and write register group for each 
channel includes ten control registers, two 
sync-character registers, and four status 
registers. Each baud rate generator has two 
read/write registers for holding the time con- 
stant that determines baud rate. Associated 
with the interrupt logic is a write register for 
interrupt vector and three read registers: vec- 
tor with status, vector without status, and inter- 
rupt pending status. 

The logic for both channels provides format- 
ting, synchronization and validation for data 
transferred to and from the channel interface. 
The modem control inputs are monitored by 
the control logic under program control. All of 
the modem control signals are general purpose 
in nature and optionally can be used for func- 
tions other than modem control. 
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Figure 3. Functional Block Diagram 



Typical Figure 4 shows how a Z-SCC can be con- 

Applications nected with channel A programmed for the 
Synchronous Data Link Control (SDLC) Loop 
mode, functioning as a secondary station. If 
NRZI or FM coding is used, no clock lines are 
required because the clock can be recovered 
from the received data, using the Z-SCC's on- 
chip digital phase locked loop (DPLL) . 
. Another Z-SCC (not shown), programmed for 
the SDLC mode, would be the controlling sta- 
tion, poUing the loop for traffic. The figure 
shows a typical, asynchronous serial port 
being serviced by channel B of the Z-SCC. It 
could just as well support another synchronous 
data link, or even a high-speed link, transfer- 
ring data via a DMA controller. 
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FIFO Input/Output 

Interlace Unit 



Zilog 



Product 
Brief 



Preliminary 



February 1980 



Features ■ Asynchronous bidirectional FIFO buffer, 

used with most major microprocessors as 
CPU/CPU or CPU/peripheral interface. 

■ Interlocked 2-wire or 3-wire handshake port 
mode; Empty, Full, and Request/Wait lines 
for high-speed data transfer. 

■ 128 X 8 organization, expandable to any 
width; cascadable to any depth. 



Preset byte count in FIO buffer can inter- 
rupt CPU. 

All registers directly addressable. 

Vectored/non- vectored interrupts on 
pattern/status match, over/underflow error, 
buffer status. 



Description The Z-FIO is a general-purpose micro- 

processor interface that provides elastic buffer- 
ing between asynchronous CPUs in a parallel- 
processor network or between CPU and 
peripheral circuits. The Z-FIO can interface a 
Z-Bus microprocessor or any other major pro- 
cessor to another microprocessor or to a 
peripheral circuit or port. 

In Z8000 systems, the FIO furthers dis- 
tributed-processor operation because it can 
interconnect components or subsystems 
operating at different speeds. Also, it can 
increase system throughput by transferring 



words as well as bytes. This bidirectional 
device accepts data and holds it until it can be 
used by another device in the system. In most 
I/O transactions, introducing a 128-deep buffer 
cuts interrupt servicing overhead by two 
orders of magnitude. 

The Z-FIO greatly facilitates system 
throughput by moving variable-size blocks 
under either direct memory access or interrupt 
control — an especially important consideration 
when fast peripheral circuits need interfacing. 
Complete status information is also provided 
for operation in polled environments. 
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Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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Pin 
Assignments 



H 
B 

E 

a 

E 

[h] 

B 
ffl 



Z-Bus 
Low Byte 


Z-Bus 
High Byte 


Non-Z-Bus 


REQ/WT 


, REQ/WT 


REQ/WT 


DMASTB 


DMASTB 


DACK 


DS 


DS 


RD 


R/W 


R/W 


WR 


CS 


CS 


CS 


AS 


AS 

Ao 


C/D 


INTACK 


INTACK 


lEO 


A, 


lEO 


lEI 


A2 


lEI 


iNT 


A3 


INT 



2- Wire 
HS Port* 



RFD/DAV 

ackIn 

FULL 
EMPTY 



CLEAR 

DATA DIR 

INo 

OUT, 

of 

OUT. 



3-Wire 
HS Port* 



RFD/DAV 

DAV/DAC 

DAC/RFD 

EMPTY 



CLEAR 

DATA DIR 

INo 

QUTi 

Of 

OUTo 



'Port 2 side only. See table below. 



Description The internal functions of the Z-FIO are 

(Continued) shown in the block diagram (Figure 3). It is 

made up of two ports that are identical except 
for programming. The port programmed by 
pins Mq and Mi is called Port 1; the port pro- 
grammed by bits Bq and Bj is called Port 2. 
Each port of the FIO has sixteen program- 
mable registers that define operating protocols 
and pin signals. Common to both ports, and 
situated between them, is the 128 X 8 RAM 
used for data storage. The RAM is capable of 
simultaneous, independent read and write 
operations. This means, for example, that the 
Port 1 CPU can write a byte of data into the 
FIO without disturbing a simultaneous read 
operation by the Port 2 CPU. The outputs of 
the read and write counters are used to 



address the buffer RAM, and also are fed into 
a subtracter to determine the current number 
of bytes in the memory. This number can be 
read by either CPU from a status register 
dedicated to each port. Another programmable 
register is compared against the status register 
to generate interrupts and/or start and stop 
DMA transfers. A pair of port registers allows 
for communication between CPUs, bypassing 
the main buffer memory. 

Operating Modes. The Z-FIO has twelve 
different programmable modes (Table below). 
The states of two package pins determine the 
mode of operation of Port 1 , and Port 2 is pro- 
grammed by two bits (Bq and Bi) in one of the 
Port 1 control registers. 
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^ 
^ 



128 X8 
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CONTROL/ 
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BUFFER 
PORT 2 
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CONTROL/ 
STATUS 
PORT 2 

REGISTERS 
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Z'BUS 
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MICROPROCESSOR 
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CONTROL/ 

INTERFACE 

LOGIC 

PORT 2 



Figure 3. Functional Block Diagram 



Operating 
Modes 



Mode Ml Mo Bi Bq 



1 









Z-Bus Low By 
Z-Bus Low By 
Z-Bus Low 
Z-Bus Low By 

Z-Bus High By 
Z-Bus High By 
Z-Bus High By 
Z-Bus High By 

Non-Z-Bus 
Non-Z-Bus 
Non-Z-Bus 
Non-Z-Bus 



Z-Bus Low Byte 
Non-Z-Bus 
3- Wire HS 
2-Wire HS 

Z-Bus High Byte 
Non-Z-Bus 
3-Wire HS 
2-Wire HS 
Z-Bus Low Byte 
Non-Z-Bus Low Byte 
3-Wire HS 
2-Wire HS 
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Z8060 FIFO 
FIFO Buffer Unit 
and Z-FIO Expander 



Zilog 



Product 
Brief 



Preliminary 



February 1980 



Features ■ Asynchronous, bidirectional first-in, first-out 

buffer. 

■ Extends depth of Z-FIO without limit. 

■ 128 X 8 organization. 



3-state data outputs. 

Empty and Full status pins are wire-ORed 
among multiple stages. 



Description The Z-FIFO first-in, first-out buffer unit is a 

128 X 8-bit memory with bidirectional data 
transfer capability and handshake logic. Its 
structure is similar to that of other FIFOs that 
are commonly available, such as the AM2812 
and the 3351. The handshake logic used is 
compatible with that of the Z8, the Z-CIO, and 
Z-FIO. Z-FIFO buffers can be casc aded , end to 
end, without limit, their RFD/DAV and ACKIN 
signals daisy-chained, to make a FIFO array 
any desired number of words deep. Two such 
channels in parallel, suitably controlled, make 
up a 16-bit-wide buffer array. 
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Figure I. Pin Functions 
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Figure 2. Using FIFOs to Extend FIOs 
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■1 



Til 



"7^1 



Zilog 



Appendix C 





Operands 


Addr. 




■■ 


Clock Cycles* 


^ 






Mnemonics 


Word. Byte 


Long Word 


Operation 






Modes 


NS 


SS 


SL 


NS 


SS 


SL 




ADC 


R,src 


R 


5 












Add with Carry 


ADCB 


















R — R + src + carry 


ADD 


R,src 


R 


4 


4 


4 


8 


8 


8 


Add 


ADDB 




IM 


7 


7 


7 


14 


14 


14 


R - R + src 


ADDL 




IR 


7 






14 












DA 


9 


10 


12 


15 


16 


18 








X 


10 


10 


13 


16 


16 


19 




AND 


R,src 


R 


4 


4 


4 








AND 


ANDB 




IM 
IR 
DA 
X 


7 

7 

9 

10 


7 

10 

10 


7 

12 

13 








R - R AND src 


BIT 


dst,b 


R 


4 


4 


4 








Test Bit Static 


BITB 




IR 
DA 
X 


8 

10 

11 


11 
11 


13 
14 








Z flag - NOT dst bit specified by b 


BIT 


dst,R 


R 


10 


10 


10 








Test Bit Dynamic 


BITB 


















Z flag — NOT dst bit specified by 
contents of R 


CALL 


dst 


IR 


10 


10 


15 








Call Subroutine 






DA 


12 


18 


20 








Autodecrement SP 






X 


13 


18 


21 








@ SP - PC 
PC - dst 


CALR 


dst 


RA 


10 


10 


15 








Call Relative 

Autodecrement SP 

@ SP - PC 

PC - PC + dst( range -4094 to 

+ 4096) 


CLR 


dst 


R 


7 


7 


7 








Cleor 


CLRB 




IR 
DA 
X 


8 

11 
12 


12 
12 


14 

IS 








dst ~ 


COM 


dst 


R 


7 


7 


7 








Complement 


COMB 




IR 
DA 
X 


12 
15 

16 


16 
16 


18 
19 








dst - NOT dst 


COMFLG 


flags 




7 


7 


7 








Complement Flag 

(Any combination of C, Z, S, P/V) 


CP 


R,src 


R 


4 


4 


4 


8 


8 


8 


Compare with Register 


CPB 




IM 


7 


7 


7 


14 


14 


14 


R - src 


CPL 




IR 


7 






14 












DA 


9 


10 


12 


15 


16 


18 








X 


10 


10 


13 


16 


16 


19 




CP 


dst.IM 


IR 


11 












Compare with Immediate 


CPB 




DA 
X 


14 
15 


15 
15 


17 
18 








dst - IM 


* NS = Non-Segmented, SS = 


Short Segmented Offset, SL 


= Segmented Long 


r Offset, 


Blank 


= Not Implemented. 



C-1 



Clock Cycles 

Mnemonics Operonds Addr. Word, Byte Long Word 

Modes NS SS SL NS SS SL 



Operation 



CPD Rx,src,Ry,cc IR 20 

CPDB 



Compare and Decrement 

Rx - src 

Autodecrement src address 

Ry •" Ry ~ ^ 



CPDR Rx,src,RY,cc IR (11 + 9n) 

CPDRB 



Compore, Decrement and Repeat 

Ry - src 

Autodecrement src address 

Rx *- Ry - 1 

Repeat until cc is true or Ry = 



CPI 
CPIB 



Rx,src,Ry,cc IR 



20 



Compare and Increment 

Rx - src 

Autoincrement src address 

Ry *~ Ry ~ 1 



CPIR 
CPIRB 



Rx,src,RY,cc IR 



(11 + 9n) 



Compare, Increment and Repeat 

Rx - src 

Autoincrement src address 

Ry -^ Ry — 1 

Repeat until cc is true or Ry = 



CPSD 
CPSDB 



dst,src,R,cc 



IR 



25 



Compare String and Decrement 

dst - src 

Autodecrement dst and src addresses 

R - R- 1 



CPSDR 
CPSDRB 



dst,src,R,cc 



IR 



(11 + 14n) 



Compare Siring, Deer, and Repeat 

dst - src 

Autodecrement dst and src addresses 

R - R - 1 

Repeat until cc is true or R = 



CPSI 
CPSIB 



dst,src,R,cc 



IR 



25 



Compare String and Increment 

dst - src 

Autoincrement dst and src addresses 

R - R - 1 



CPSIR 
CPSIRB 



dst,src,R,cc 



IR 



(11 + 14n) 



Compare String, Incr. and Repeat 

dst - src 

Autoincrement dst and src addresses 

R - R - 1 

Repeat until cc is true or R = 



DAB 



dst 



Decimal Adjust 



DEC 
DECB 



dst,n 



R 


4 


4 


4 


IR 


11 






DA 


13 


14 


16 


X 


14 


14 


17 



Decrement by n 

dst — dst - n 
(n = 1...16) 



DI* 



Disable Interrupt 

(Any combination of NVI, VI) 



DIV 
DIVL 



R.src 



R 
IM 

IR 
DA 

X 



107 
107 

107 107 107 

108 109 111 

109 109 112 



744 
744 

744 744 744 

745 746 748 

746 746 749 



Divide (signed) 



Word: R, 



n + I 



- R. 



n,n + 1 ■ 



R„— remainder 
Long Word: R^ + 2,n + 3~ Rn...n + 3+ src 
^n,n + 1 *~ remainder 



'Privileged instruction. Executed in system mode only. 



C-2 



EX 
EXB 



INC 
INCB 



Clock Cycles 



Mnemonics Operands 



Addr. 
Modes 



Word, Byte 
NS SS SL 



Long Word 
NS SS SL 



Operation 



DJNZ 
DBINZ 


R,dst 


RA 


11 


11 


11 


Decrement and Jump if Non-Zero 

R ~ R - 1 

If R ;t 0: PC - PC + dst(range -254 to 0) 


EI* 


int 




7 


7 


7 


Enable Interrupt 

(Any combination of NVI, VI) 



R.src 



dst,n 



R 


6 


6 


6 


IR 


12 






DA 


15 


16 


18 


X 


16 


16 


19 



Exchange 

R — src 



EXTS 

EXTSB 

EXTSL 


dst 


R 


11 


11 


11 


11 


11 


11 


Extend Sign 

Extend sign of low order half of dst 
through high order half of dst 


HALT* 






(8 


+ 3n) 


1 








HALT 


IN* 
INB* 


R,src 


IR 
DA 


10 
12 


12 


12 








Input 

R ~ src 



R 


4 


4 


4 


IR 


11 






DA 


13 


14 


16 


X 


14 


14 


17 



Increment by n 

dst — dst + n 
(n = 1...16) 



IND* 
INDB* 



dst, src, R 



IR 



Input and Decrement 

dst — src 

Autodecrement dst addresed 

R - R - 1 



INDR* 
INDRB* 



dst, src, R 



IR 



(11 + lOn) 



Input, Decrement and Repeat 

dst — src 

Autodecrement dst address 
R - R - 1 
Repeat until R = 



INI* 
INIB* 



dst, src, R 



IR 



Input and Increment 

dst — src 

Autoincrement dst address 

R - R - 1 



INIR* 
INIRB* 



dst, src, R 



IR 



(11 + lOn) 



Input, Increment and Repeat 

dst — src 

Autoincrement dst address 
R ~ R - 1 
Repeat until R = 



IRET* 



13 13 16 



Interrupt Return 

PS - @ SP 
Autoincrement SP 



IP 



CO, dst 



IR 


10 




15 


(taken) 


lump Conditional 


IR 


7 




7 


(not taken) 


If cc is true: PC - dst 


DA 


7 


8 


10 






X 


8 


8 


11 







IR 



cc,dst 



RA 



Jump Conditional Relative 

If cc is true: PC - PC + dst 
(range -256 to +254) 



^Privileged instruction. Executed in system mode only. 



C-3 



Clock Cycles 



Mnemonics Operands 



Addr. 
Modes 



Word, Byte 
NS SS SL 



Long Word 
NS SS SL 



Operotion 



LD 

LDB 

LDL 



R,src 



R 
IM 
IM 
IR 
DA 
X 

BA 
BX 



3 3 

7 7 

(byte only) 



10 
10 



Load into Register 

R — src 



LD 

LDB 

LDL 



dst,R 



IR 
DA 

X 

BA 
BX 



Load into Memory (Store) 
dst - R 



LD 
LDB 



dst,IM 



IR 
DA 
X 



Load Immediate into Memory 

dst - IM 



LDA 



R.src 



DA 


12 


13 


15 


X 


13 


13 


16 


BA 


15 


15 


15 


BX 


15 


15 


15 



LDD 
LDDB 



dst, src, R 



IR 



20 



Load Address 

R — source address 



LDAR 


R,src 


RA 


15 


15 


15 


Load Address Relative 


LDCTL* 


CTLR,src 


R 


7 


7 


7 


Load into Control Register 

CTLR ~ src 


LDCTL* 


dst.CLTR 


R 


7 


7 


7 


Load from Control Register 

dst - CTLR 


LDCTLB 


FLGR,src 


R 


7 


7 


7 


Load into Flag Byte Register 

FLGR - src 


LDCTLB 


dst,FLGR 


R 


7 


7 


7 


Load irom Flag Byte Register 

dst - FLGR 



Load and Decrement 

dst — src 

Autodecrement dst and src addresses 

R - R + 1 



LDDR 
LDDRB 



dst, src, R 



IR 



(11 + 9n) 



Load, Decrement and Repeat 

dst — src 

Autodecrement dst and src addresses 

R - R - 1 

Repeat until R = 



LDI 
LDIB 



dst, src, R 



IR 



20 



Load and Increment 

dst — src 

Autoincrement dst and src addresses 

R - R - 1 



LDIR 
LDIRB 



dst, src, R 



IR 



(11 + 9n) 



Load, Increment and Repeat 

dst "- src 

Autoincrement dst and src addresses 

R - R - 1 

Repeat until R = 



C-4 



MULT 
MULTL 



Clock Cycles 



Mnemonics Operands 



R,src 



Addr. 
Modes 



Word, Byte 
NS SS SL 



Long Word 
NS SS SL 



Operation 



LDK 


R,src 


IM 


5 


5 


5 








Load Constant 

R - n (n = 0...15) 


LDM 


R,src,n 


IR 
DA 
X 


11 
14 

15 


15 
15 


17 
18 


+ 3n 






Load Multiple 

dst — src (n consecutive words) 
(n = 1...16) 


LDM 


dst,R,n 


IR 
DA 
X 


11 
14 

15 


15 

15 


17 
18 


+ 3n 






Load Multiple (Store Multiple) 
dst — R (n consecutive words) 
(n = 1...16) 


LDPS* 


src 


IR 
DA 
X 


12 
16 
17 


20 
20 


22 
23 








Load Program Status 

PS - src 


LDR 
LDRB 


R,src 


RA 


14 


14 


14 


17 


17 


17 


Load Relative 

R - src 

(range -32768... +32767) 


LDR 

LDRB 

LDRL 


dst,R 


RA 


14 


14 


14 


17 


17 


17 


Load Relative (Store Relative) 

dst - R 

(range -32768... +32767) 


MBIT* 






7 


7 


7 








Test Multi-Micro Bit 

Set if Mj is Low; reset S if Mj is High. 


MREQ* 


dst 


R 


(12 


+ 7n: 


) 








Multi-Mircre Request 


MRES* 






5 


5 


5 








Multi-Micro Reset 


MSET* 






5 


5 


5 








Multi-Micro Set 



R 
IM 

IR 
DA 

X 



70 
70 
70 
71 
72 



72 
72 



282 + 282 + 282 + Multiply (signed) 

282 + 282 + 282 + Word: R^ „ + j - R„ + j . src 

282+ Long Word: Rn...n + 3-Rn + 2, n + 3 • src 

283 + 283 + 286 + + Plus seven cycles for each 1 in the 

284 + 284 + 287 + absolute value of the low order 16 bits of the 

multiplicand. 



NEG 
NEGB 



dst 



R 
IR 
DA 
X 



7 7 7 
12 

15 16 18 

16 16 19 



Negate 

dst - - dst 



NOP 



No Operation 



OR 
ORB 



R,src 



R 
IM 

IR 
DA 

X 



4 
7 
7 
9 
10 



10 
10 



OR 

R - R OR src 



OTDR* 
OTDRB* 



dst, src, r 



IR 



(11 + 10 n) 



Output, Decrement and Repeat 

dst — src 

Autodecrement src address 
R - R - 1 
Repeat until R = 



*Privileged instructions. Executed in system mode only. 



C-5 



Clock Cycles 



Mnemonics Operands 



Addr. 
Modes 



Word, Byte 
NS SS SL 



Long Word 
NS SS SL 



Operation 



OTIR* 
OTIRB* 



dst,src,R 



IR 



(11 + 10 n) 



Output, Increment and Repeat 

dst — src 

Autoincrement scr address 
R - R - 1 
Repeat until R = 



OUT* 
OUTB* 



dst,R 



IR 
DA 



12 



12 



Output 

dst - R 



OUTD* 
OUTDB* 



dst, src, R 



IR 



Output and Decrement 

dst — src 

Autodecrement src address 

R - R - 1 



OUTI* 
OUTIB* 



dst, src, R 



IR 



Output and Increment 

dst — src 

Autoincrement src address 

R - R - 1 



POP 
POPL 



dst,IR 



R 
IR 
DA 
X 



12 



23 
23 



12 



25 
26 



Pop 

dst - IR 

Autoincrement contents of R 



PUSH 
PUSHL 



IR,src 



R 
IM 

IR 
DA 

X 



20 
16 
21 



Push 

Autodecrement contents of R 
IR - src 



RES 
RESB 



dst,b 



R 
IR 
DA 
X 



4 4 
11 

13 14 

14 14 



Reset Bit Static 

Reset dst bit specified by b 



RES 
RESB 


dst,R 


R 


10 10 


10 




Reset Bit Dynamic 

Reset dst bit specified by contents R 


RESFLG 


flag 




7 7 


7 




Reset Flag 

(Any combination of C, Z, S, P/V) 


RET 


cc 




10 10 
7 7 


13 
7 


(taken) 
(not taken) 


Return Conditional 

If cc is true: PC - @ SP Autoincrement SP 


RL 
RLB 


dst,n 


R 
R 


6 for n = 

7 for n = 


1 
2 




Rotate Left 

by nbits (n = 1, 2) 


RLC 
RLCB 


dst.n 


R 
R 


6 for n = 

7 for n = 


1 
2 




Rotate Left through Carry 

by n bits (n = 1, 2) 


RLDB 


R,src 


R 


9 9 


9 




Rotate Digit Left 


RR 
RRb 


dst.n 


R 
R 


6 for n = 

7 for n = 


1 
2 




Rotate Right 

by n bits (n = 1 , 2) 


RRC 
RRCB 


dst,n 


R 
R 


6 for n = 

7 for n = 


1 
2 




Rotate Right through Carry 

by n bits (n = 1, 2) 



'Privileged instruction. Executed in system mode only. 



C-6 



sc 



SET 
SETB 



SIND* 
SINDB* 



Clock Cycles 



Mnemonics Operands Addr. Word, Byte 

Modes NS SS SL 



Long Word 
NS SS SL 



Operation 



RRDB 


R,src 


R 


9 


9 


9 


Rotate Digit Right 


SBC 
SBCB 


R,src 


R 


5 


5 


5 


Subtract with Carry 

R — R - src - carry 



dst,b 



dst,src,R 



IM 



33 



39 



System Call 

Autodecrement SP 
@ SP - old PS 
Push instruction 
PS - System Call PS 



SDA 

SDAB 

SDAL 


dst,R 


R 


(15 + 3n) 


(15 + 3n) 


Shift Dynamic Arithmetic 

Shift dst left or right 
by contents of R 


SDL 

SDLB 

SDLL 


dst,R 


R 


(15 + 3n) 


(15 + 3n) 


Shift Dynamic Logical 

Shift dst left or right 
by contents of R 



R 


4 


4 


4 


IR 


11 






DA 


13 


14 


16 


X 


14 


14 


17 



Set Bit Static 

Set dst bit specified by b 



SET 
SETB 


dst,R 


R 


10 


10 


10 


Set Bit Dynamic 

Set dst bit specified by contents of R 


SETFLG 


flag 


X 


7 


7 


7 


Set Flag 

(Any combination of C, Z, S, P/V) 


SIN* 
SINB* 


R.src 


DA 


12 


12 


12 


Special Input 

R — src 



IR 



Special Input and Decrement 

dst — src 

Autodecrement dst address 

R - R - 1 



SINDR* 
SINDRB* 



dst, src, R 



(11 + lOn) 



Special Input, Decrement and Repeat 

dst — src 

Autodecrement dst address 
R - R - 1 
Repeat until R = 



SINI* 
SINIB* 



dst, src, R 



IR 



Special Input and Increment 

dst — src 

Autoincrement dst address 

R - R - 1 



SINIR* 
SINIRB* 



dst, src, R 



IR 



(11 + lOn) 



Special Input, Increment and Repeat 

dst — src 

Autoincrement dst address 
R ~ R - 1 
Repeat until R = 



SLA 

SLAB 

SLAL 



dst,n 



(13 + 3n) 



(13 + 3n) 



Shift Left Arithmetic 

by n bits 



SLL 

SLLB 

SLLL 



dst,n 



(13 + 3n) 



(13 + 3n) 



Shift Left Logical 

by n bits 



'Privileged instruction. Executed in system mode only. 



C-7 



Clock Cycles 



Mnemonics Operands Addr. Word, Byte 

Modes NS SS SL 



Long Word 
NS SS SL 



Operation 



SOTDR* dst,src,R 

SOTDRB* 



IR 



(11 + 10 n) 



Special Output, Deer, and Repeat 

dst — src 

Autodecrement src address 
R - R - 1 
Repeat until R = 



SOTIR* dst, src, R 

SOTIRB* 



(11 + 10 n) 



Special Output, Incr. and Repeat 

dst — src 

Autoincrement src address 
R - R - 1 
Repeat until R = 



SOUT* dst, src 

SOUTB* 



DA 12 12 12 



Special Output 

dst — src 



SOUTD* dst,src,R 

SOUTDB* 



IR 21 



Special Output and Decrement 

dst — src 

Autodecrement src address 

R - R - 1 



SOUTI* dst,src,R IR 21 

SOUTIB* 



Special Output ond Increment 

dst — src 

Autoincrement src address 

R ~ R - 1 



SRA 

SRAB 

SRAL 



dst,n 



(13 + 3n) 



(13 + 3n) 



Shiit Right Arithmetic 

by n bits 



SRL 

SRLB 

SRLL 



dst,n 



(13 + 3n) 



(13 + 3n) 



Shift Right Logical 

by n bits 



SUB 

SUBB 

SUBL 



R,src 



R 


4 


4 


4 


8 


8 


8 


Subtract 


IM 


7 


7 


7 


14 


14 


14 


R - R - src 


IR 


7 






14 








DA 


9 


10 


12 


15 


16 


18 




X 


10 


10 


13 


16 


16 


19 





TCC 
TCCB 



cc,dst 



Test Condition Code 

Set LSB if cc is true 



TEST 
TESTB 



dst 



R 


7 


7 


7 


13 


13 


13 


Test 


IR 


8 






13 






dst OR 


DA 


11 


12 


14 


16 


17 


19 




X 


12 


12 


15 


17 


17 


20 





'Privileged instructions. Executed in system mode only. 
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Clock Cycles 



Mnemonics Operands 



Addr. 
Modes 



Word, Byte 
NS SS SL 



Long Word 
NS SS SL 



Operation 



TRDB 



dst,src,R 



IR 



25 



Translate and Decrement 

dst — src(dst) 
Autodecrement dst address 
R - R - 1 



TRDRB 



dst,src,R 



IR 



(11 + 14n) 



Tronslate, Decrement and Repeat 

dst — src(dst) 
Autodecrement dst address 
R - R - 1 
Repeat until R = 



TRIB 



dst,src,R 



IR 



25 



Translate and Increment 

dst — src(dst) 
Autoincrement dst address 
R - R - 1 



TRIRB 



dst,src,R 



IR 



(11 + 14n) 



Tronslate, Increment and Repeat 

dst — src(dst) 
Autoincrement dst address 
R - R - 1 
Repeat until R = 



TRTDB 



srcl,src2,R 



IR 



25 



Translote ond Test, Decrement 

RHl - src2(srcl) 
Autodecrement src 1 address 
R - R - 1 



TRTDRB 



srcl,src2,R 



IR 



(11 + 14n) 



Translate and Test, Deer, and Repeat 

RHl - src2 (srcl) 
Autodecrement src 1 address 
R - R - 1 
Repeat until R = or RHl * 



TRTIB 



srcl,src2,R 



IR 



25 



Translate ond Test, Increment 

RHl - src2(srcl) 
Autoincrement src address 
R - R - 1 



TRTIRB 



srcl,src2,R 



(11 + 14n) 



Translate and Test, Incr. and Repeat 

RHl - src2 (srcl) 
Autoincrement src 1 address 
R - Rl 
Repeat until R = or RHl ^t 



TSET 
TSETB 



dst 



R 7 7 7 

IR 11 

DA 14 15 17 

X 15 15 18 



Test and Set 

S flag - MSB of dst 
dst ~ all Is 



XOR 
XORB 



R,src 



R 


4 


4 


4 


IM 


7 


7 


7 


IR 


7 






DA 


9 


10 


12 


X 


10 


10 


13 



Exclusive OR 

R - R XOR src 
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LOWER NIBBLE (HEX), UPPER INSTRUCTION BYTE 








1 


2 


3 


4 


s 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 





AODB 

R — m 

R — IM 


ADD 

R - IR 
R — IM 


SUBB 

R — !R 
R — IM 


SUB 

R — IR 
R — IM 


ORB 

R — IR 
R — IM 


OH 

R — IR 
R — IM 


ANDB 

R — IR 
R — IM 


AND 

R — IR 
R — IM 


XORB 

R — IR 
R — IM 


XOR 

R — IR 
R — IM 


CPB 

R — IR 
R — IM 


CP 

R — IR 
R - IM 


Sm 

Tabl* 

1 


Sm 

Tabl* 
1 


EXTEND 
INST 


EXTEND 
INST 


1 


CPL 

R — IR 
R — IM 


PUSHL 

IR — IR 


SUBL 

R — IR 
R ^ IM 


PUSH 

IR — IR 


LDL 

R — IR 
R — IM 


POPL 

IR — IR 


ADDL 

R — IR 
R — IM 


POP 

IR — IR 


MULTL 

R — IR 
R — IM 


MULT 

R — IR 
R — IM 


DIVL 

R — IR 
R — IM 


DIV 

R — IR 
R — IM 


Sm 

Tabl* 
2 


LDL 

IR-R 


IP 

PC-IR 


CALL 

PC — IR 


2 


LDB 

R — IR 
R — IM 


LD 

R — !R 
R — IM 


RESB 

IR — IM 
R — R . 


RES 

IR — IM 
R — R 


SETB 

IR — IM 
R — R 


SET 

IR — IM 
R — R 


BITB 

IR — IM 
R — R 


BIT 

IR — IM 
R — R 


INCB 

IR — IM 


INC 

IR — IM 


DECB 

IR — IM 


DEC 

IR — IM 


EXB 

R-IR 


EX 

R— IR 


LDB 

IR— R 


LD 

IR— R 


3 


LDB 

R — BA 
LDRB 

R — RA 


LD 

R — BA 
LDR 

R — RA 


LDB 

BA — R 
LDRB 

RA — R 


LD 

BA — R 
LDR 

RA — R 


LDA 

R — BA 
LDAR 

R — RA 


LDL 

R — BA 
LDRL 

R — RA 


HSVD 


LDL 

BA ^ R 
LDRL 

RA — R 


RSVD 


IDPS 

IR 


Sm 

Tabl* 
3A 


Sm 

Tabl* 
3lB 


INB 

R-IR 


IN 

R— IR 


OUTB 

IR— R 


OUT 

IR— R 


4 


ASDB 

R ~X 

R — DA 


ADD 

R — X 
R ~ DA 


SUBB 

R — X 
R — DA 


SUB 

R — X 
R — DA 


ORB 

R — X 
R — DA 


OR 

R — X 
R — DA 


ANDB 

R — X 

R — DA 


AND 

R — X 
R — DA 


XORB 

R — X 

R — DA 


XOR 

R - X 
R — DA 


CPB 

R — X 

R — DA 


CP 

R — X 

R — DA 


Sm 

Tabl* 
1 


Sm 

Tabl* 
1 


EXTEND 
INST 


EXTEND 
INST 


5 


CPL 

R — X 
R — DA 


PUSHL 

IR — X 
IR — DA 


SUBL 

R — X 

R — DA 


PUSH 

IR — X 
IR — DA 


LDL 

R — X 

R — DA 


POPL 

IR — X 
IR —DA 


ADDL 

R — X 
R — DA 


POP 

IR— X 
IR —DA 


MULTL 

R - X 

R — DA 


MULT 

R — X 

R — DA 


DIVL 

R — X 
R — DA 


DIV 

R — X 


Sm 
Tabl* 

2 


LDL 

X— R 
DA— R 


IP 

PC— X 
PC -DA 


CALL 

PC-X 
PC— DA 


6 


LDB 

R — X 
R — DA 


LD 

R — X 
R — DA 


RESB 

X — IM 
DA — IM 


RES 

X — IM 
DA — IM 


SETB 

X — IM 
DA — IM 


SET 

X — IM 
DA — IM 


BITB 

X — IM 
DA — IM 


BIT 

X — IM 
DA — IM 


INCB 

X — IM 
DA — IM 


INC 

X — IM 
DA — IM 


DECB 

X — IM 
DA — IM 


DEC 

X — IM 

DA — IM 


EXB 

R-X 
R-DA 


EX 

R-X 
R-DA 


LDB 

X-R 
DA-R 


LD 

X-F 
DA-R 


7 


LDB 

R — BX 


Sm 

Tobl* 
7 


LDB 

BX ^ R 


LD 

BX — R 


LDA 

R — BX 


LDL 

R — BX 


LDA 

R — X 

R — DA 


LDL 

BX — R 


RSVD 


LDPS 

PS — X 
PS — DA 


HALT 


Sm 

Tabl* 
7 


EI 
Dl 


Sm 

Tabl* 

7 


RSVD 


SC 


8 


ADDB 

R — R 


ADD 

R — R 


SUBB 

R — R 


SUB 

R — R- 


ORB 

R ~ R 


OR 

R — R 


ANDB 

R — R 


AND 

R — R 


XORB 

R — R 


XOR 

R — R . 


CPB 

R — R 


CP 

R — R 


Sm 

Tabl* 
1 


Sm 

Tabl* 
1 


EXTEND 
INST. 


EXTEND 

INST. 


9 


CPL 

R — R 


PUSHL 

IR — R 


SUBL 

R — R 


PUSH 

IR — R 


LDL 

, R — R 


POPL 

R — IR 


ADDL 

R — R 


POP 

R — IR 


MULTL 

R — R 


MULT 

R — R 


DIVL 

R — R 


DIV 

R — R 


Sm 

Tabl* 
2 


RSVD 


RET 

PC-(SP) 


RSVD 


A 


LDB 

R — R 


LD 

R ^ R 


RESB 

R — IM 


RES 

R — IM 


SETB 

R — IM 


SET 

R — IM 


BITB 

R — I>i 


BIT 

R — IM 


INCB 

R — IM 


INC 

R — IM 


DECB 

R — IM 


DEC 

R — IM 


EXB 

R-R 


EX 

R-R 


TCCB 

R 


TCC 

R 


B 


DAB 

R 


EXTS 

EXTSB 

EXTSL 

R 


Sm 

TabU 

4 


Sm 

TabU 
4 


ADCB 

R — R 


ADC 

R — R 


SBCB 

R — R 


SBC 

R — R 


Sm 

TabU 
S 


RSVD 


Sm 

Tabu 
6 


Sm 

Tabl* 
6 


RRDB 

R 


LDK 

R-IM 


RLDB 

R 


RSVD 




LDB 

R — IM 


































































CALR 

PC — RA 
































































E 


IR 

PC — RA 
































































DINZ 
DBINZ 

PC — RA 

- ... 

































































Notes: 



Op Code Map 



1) Reserved Instructions (RSVD) should not be 
used. The result of their execution is not defined. 

2) The execution of an extended instruction will 
result in an Extended Instruction Trap if the EPA 
bit in the FCW is a zero. If the flag is a one the 
Extended Instruction will be executed by the EPU 
function. 
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oc 


OD 


COMB 

IR 


COM 

IR 


CPB 

IR.IM 


CP 

IR.IM 


NEGB 

IR 


NEC 

IR 


RSVD 


RSVD 


TESTB 

IR 


TEST 

IR 


LDB 

IR— IM 


LD 

IR-IM 


TSETB 

IR 


TSET 

IR 


RSVD 


RSVD 


CLRB 

IR 


cut 

IR 




PUSH 

IM 



4C 


4D 


COMB 

X 

DA 


COM 

X 
DA 


CPB 

X,IM 
DA.IM 


CP 

X.IM 

DA.IM 


NEGB 

X 
DA 


NEC 
X 

DA 


RSVD 


RSVD 


TESTB 
X 

DA 


TEST 

X 
DA 


LDB 

X-IM 
DA-IM 


LD 

X-IM 
DA-IM 


TSETB 

X 
DA 


TSET 
X 

DA 


RSVD 


RSVD 


CLRB 

X 
DA 


CLR 

X 

DA 



Table 1 . Upper Instruction Byte 



8C 


8D 


COMB 

R 


COM 

R 


LDCTLB 

R-FLGS 


SETFLG 


NEGB 

R 


NEG 

R 


RSVD 


RESFLG 


TESTB 

R 


TEST 

R 


RSVD 


COMFLG 


TSETB 

R 


TSET 

R 


RSVD 


NOP 


CLRB 

R 


CLR 

R 


LDCTLB 

FLGS-R 





"RSXm" 



LDM 

R-IR 



LDM 

IR-R 



LDM 

R— X 

R— DA 



LDM 

X-R 

DA-R 





INIB 


INI 





IR-IR 


IR-IR 




INIRB 


INIR 




IR-IR 


IR-IR 




SINIB 


SINI 


I 


IR-IR 


IR-IR 




SINIRB 


SINIR 




IR-IR 


IR-IR 




OUTIB 


OUTI 


2 


IR-IR 


IR— IR 




OTfflB 


OUTIH 




IR-IR 


IR-IR 




SOUTIB 


SOUTI 


3 


IR— IR 


IR-IR 




SOTIRB 


SOTIR 


n 


IR-IR 


IR-IR 


INB 


IN 


O ^ 


R-DA 


R-DA 


g 






1 


SINB 


SIN 


•E 5 


R-DA 


R-DA 


1 






2 


OUTB 


OUT 


i ^ 


DA-R 


DA-R 


u 






s 


SOUTB 


SOUT 


i ' 


DA-R 


DA-R 


2 


INDB 


IND 


8 


IR-IR 


IR-IR 




INDRB 


INDR 




IR-IR 


IR-IR 




SINDB 


SIND 


9 


IR-IR 


IR— IR 




SINDRB 


SINDR 




IR-IR 


IR-IR 




OUTDB 


OUTD 


A 


IR-IR 


IR-IR 




OTDRB 


OTDH 




IR-IR 


IR-IR 




SOUTDB 


SOUTD 


B 


IR-IR 


IR-IR 




SOTDRB 


SOTDR 




IR-IR 


IR-IR 



Table 2. Upper Instruction Byte 



Table 3. Upper Instruction Byte 
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B2 


B3 


RLB 

(1 bit) 
R 


RL 

(1 bit) 
R 


SUB 

R 
SRLB 

R 


SLL 

R 
SRL 

R 


RLB 

(2 bits) 
R 


RL 

(2 bits) 
R 


SDLB 

R 


SDL 

R 


RRB 

(1 bit) 
R 


RR 

(I bit) 
R 


RSVD 


SLLL 

R 
SRLL 


RRB 

(2 bits) 
R 


RR 

(2 bits) 
R 


RSVD 


SDLL 

R 


RLCB 

(1 bit) 
R 


RLC 

(1 bit) 
R 


SLAB 

R 
SRAB 

R 


SLA 

R 
SRA 

R 


RLCB 

(2 bits) 
R 


RLC 

(2 bits) 
R 


SDAB 

R 


SDA 

R 


RRCB 

(1 bit) 
R 


RRC 

(1 bit) 
R 


RSVD 


SLAL 

R 
SRAL 


RRCB 

(2 bits) 
R 


RRC 

(2 bits) 
R 


RSVD 


SDAL 

R 



CPIB 

IR 


CPI 

IR 


LDIB 

IR-IR 
LDIRB 

IR— IR 


LDI 

IR— IR 
LDIR 

IR-IR 


CPSIB 

IR 


CPSI 

IR 


RSVD 


RSVD 


CPRIB 

IR 


CPIR 

IR 


RSVD 


RSVD 


CPSIRB 

IR 


CPSIR 

IR 


RSVD 


RSVD 


CPDB 

IR 


CPD 

IR 


LDDB 

IR-IR 
LDDRB 

IR-IR 


LDD 

IR-IR 
LDDR 

IR-IR 


CPSDB 

IR 


CPSD 

IR 


RSVD 


RSVD 


CPDRB 

IR 


CPDR 

IR 


RSVD 


RSVD 


CPSDRB 

IR 


CPSDH 

IR 


RSVD 


RSVD 



7B 


7D 


IRET 

PC-(SSP) 


RSVD 


RSVD 


RSVD 


RSVD 


LDCTL 

R-FCW 


RSVD 


LDCTL 

R-RFRSH 


RSVD 


LDCTL 

R — 
PSAPSEG 


RSVD 


LDCTL 

R — 
PSAPOFF 


RSVD 


LDCTL 

R-NSPSEG 


RSVD 


LDCTL 

R-NSPOFF 


MSET 


RSVD 


MRES 


RSVD 


MBIT 


LDCTL 

FCW-R 


RSVD 


LDCTL 

RFRSH-R 


' ' 


LDCTL 

PSAPSEG 
-R 


MREQ 

R 


LDCTL 

PSAPOFF 
-R 


RSVD 


LDCTL 

NSPSEG-R 


RSVD 


LDCTL 

NSPOFF— R 



Table 4. 
Upper Instruction Byte 



Table 5. 
Upper Instruction Byte 



Table 6. 
Upper Instruction Byte 



Table 7. 
Upper Instruction Byte 



C-12 



Topical 














Index 






Data 


Addressing 


Flags 




Instruction Description 


Mnemonic 


Types 


Modes 


Aiiected 




Arithmetic 














Add with Carry 


ADC 


B, W 


R 




C, Z, S, V, D', H' 




Add 


ADD 


B, W, L 


R, IM, IR, 


DA, X 


C, Z, S, V, D', H' 




Compare (Immediate) 


CP 


B, W 


IR, DA, X 




C, Z, S, V 




Compare (Register) 


CP 


B, W, L 


R, IM, IR, 


DA, X 


C, Z, S, V 




Decimal Adjust Bit 


DAB 


B 


IR 




C, Z, S 




Decrement 


DEC 


B, W 


R, IR, DA, 


X 


Z, S, V 




Divide 


DIV 


W, L 


R, IM, IR, 


DA, X 


C, Z, S, V 




Extend Sign 


EXTS 


B, W, L 


R 




C, Z, S, V 




Increment 


INC 


B, W 


R, IR, DA, 


X 


Z, S, V 




Multiply 


MULT 


W, L 


R, IM, IR, 


DA, X 


C, Z, S, V 




Negate 


NEG 


B, W 


R, IR, DA, 


X 


C, Z, S, V 




Subtract with Carry 


SBC 


B, W 


R 




C, Z, S, V, D', H' 




Subtract 


SUB 


B, W, L 


R, IM, IR, 


DA, X 


C, Z, S, V, D', H' 




Bit Manipulation 














Bit Test 


BIT 


B, W 


R 




Z 




Bit Reset (Static) 


RES 


B, W 


R, IR, DA, 


X 


_ 




Bit Reset (Dynamic) 


RES 


B, W 


R 




_ 




Bit Set (Static) 


SET 


B, W 


R, IR, DA, 


X 


_ 




Bit Set (Dynamic) 


SET 


B, W 


R 




— 




Bit Test and Set 


TSET 


B, W 


R, IR, DA, 


X 


S 




Block Transfer and String Manipulation 














Compare and Decrement 


CPD 


B, W 


IR 




C, Z, S, V 




Compare, Decrement, and Repeat 


CPDR 


B, W 


IR 




C, Z, S, V 




Compare and Increment 


CPI 


B, W 


IR 




C, Z, S, V 




Compare, Increment, and Repeat 


CPIR 


B, W 


IR 




C, Z, S, V 




Compare String and Decrement 


CPSD 


B, W 


IR 




C, Z, S, V 




Compare String, Decrement, and Repeat 


CPSDR 


B, W 


IR 




C, Z, S, V 




Compare String and Increment 


CPSI 


B, W 


IR 




C, Z, S, V 




Compare String, Increment, and Repeat 


CPSIR 


B, W 


IR 




C, Z, S, V 




Load and Decrement 


LDD 


B, W 


IR 




V 




Load, Decrement, and Repeat 


LDDR 


B, W 


IR 




V 




Load and Increment 


LDI 


B, W 


IR 




V 




Load, Increment, and Repeat 


LDIR 


B, W 


IR 




V 




Translate and Decrement 


TRDB 


B 


IR 




Z, V 




Translate, Decrement, and Repeat 


TRDRB 


B 


IR 




Z, V 




Translate and Increment 


TRIE 


B 


IR 




Z, V 




Translate, Increment, and Repeat 


TRIRB 


B 


IR 




Z, V 




Translate, Test, and Decrement 


TRTDB 


B 


IR 




Z, V 




Translate, Test, Decrement, Repeat 


TRTDRB 


B 


IR 




Z, V 




Translate, Test, and Increment 


TRTIB 


B 


IR 




Z, V 




Translate, Test, Increment, and Repeat 


TRTIRB 


B 


IR 




Z, V 




CPU Control Instructions 














Complement Flag 


COMFLG 


— 


— 




c\ z\ s\ p^ v 




Disable Interrupt 


DI 


— 


— 




— 




Enable Interrupt 


EI 


— 


— 




— 




Halt 


HALT 


— 


— 




— 




Load Control Register (from register) 


LDCTL 


— 


R 




c^ t, s^ p^ D^ h' 




Load Control Register (to register) 


LDCTL 


— 


— 




— 




Load Program Status 


LDPS 


— 


IR, DA, X 




C, Z, S, P, D, H 




Multi-Bit Test 


MBIT 


_ 







s 




Multi-Micro Request 


MREQ 


— 


_ 




z, s 




Multi-Micro Reset 


MRES 


_ 


_ 




_ 




Multi-Micro Set 


MSET 


_ 












No Operation 


NOP 


— 


— 




— 




Reset Flag 


RESFLG 


— 


— 




C t. s', p', v" 




Set Flag 


SETFLG 


— 


- 




c^ t, s^ p^ v 



1 . Flag affected only for byte operation. 

2. Flag modified only if specified by the instruction. 
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Topical 














Index 














(Continued) 






Data 


Addressing 


Flags 




Instruction Description 


Mnemonic 


Types 


Modes 


Affected 




Input/Output Instructions" 






Regular 


Special 






Input 


(S)IN^ 


B, W 


IR, DA 


(DA) 


— 




Input and Decrement , 


(S)IND' 


B, W 


IR 


(IR) 


V 




Input, Decrement and Repeat 


(S)INDR' 


B, W 


IR 


(IR) 


V 




Input and Increment 


(S)INf 


B, W 


IR 


(IR) 


V 




Input, Increment, and Repeat 


(S)INIR' 


B, W 


IR 


(IR) 


V 




Output 


(S)OUT' 


B, W 


IR, DA 


(DA) 


— 




Output and Decrement 


(S)OUTD' 


B, W 


IR 


(IR) 


V 




Output, Decrement, and Repeat 


(S)OUTDR' 


B, W 


IR 


(IR) 


V 




Output and Increment 


(S)OUTI' 


B, W 


IR 


(IR) 


V 




Output, Increment, and Repeat 


(S)OUTIR' 


B, W 


IR 


(IR) 


- V 




Logical Instructions 














And 


AND 


B, W 


R, IM, IR, 


DA, X 


Z, S, P 




Complement 


COM 


B, W 


R, IR, DA, 


, X 


Z, S, P 




Or 


OR 


B, W 


R, IM, IR, 


DA, X 


Z, S, P 




Test 


TEST 


B, W, L 


R, IR, DA, 


,X 


Z, S, P 




Test Condition Code 


TOO 


B, W 


R 




— 




Exclusive Or 


XOR 


B, W 


R, IM, IR, 


DA, X 


Z, S, P 




Program Control Instructions 














Call Procedure 


CALL 


— 


IR, DA, X 




— 




Call Procedure Relative 


CALR 


— ' 


RA 




_ 




Decrement, Jump if Not Zero 


DJNZ 


B, W 


RA 




— 




Interrupt Return 


IRET 


— 


— 




C, Z, S, P, D, H 




Jump 


JP 


— 


IR, DA, X 




— 




Jump Relative 


JR 


— 


RA 




— 




Return From Procedure 


RET 


— 


— 




— 




System Call 


SC 


- 


- 




- 




Rotate and Shift Instructions 














Rotate Left 


RL 


B, W 


R 




_ 




Rotate Left Through Carry- 


RLC 


B, W 


R 




C, Z, S, V 




Rotate Left Digit 


RLDB 


B 


R 




Z, S 




Rotate Right 


RR 


B, W 


R 




C, Z, S, V 




Rotate Right Through Carry 


RRC 


B, W 


R 




C, Z, S, V 




Rotate Right Digit 


RRDB 


B 


R 




z, s 




Shift Dynamic Arithmetic 


SDA 


B, W, L 


R 




C, Z, S, V 




Shift Dynamic Logical 


SDL 


B, W, L 


- R 




C, Z, S, V 




Shift Left Arithmetic 


SLA 


B, W, L 


R 




C, Z, S, V 




Shift Left Logical 


SLL 


B, W, L 


R 




C, Z, S, V 




Shift Right Arithmetic 


SRA 


B, W, L 


R 




C, Z, S, V 




Shift Right Logical 


SRL 


B, W, L 


R 




C, Z, S, V 



3. Each I/O instruction has a Special counterpart used to alert other devices that a Special I/O transaction is occur- 
ring. The Special I/O mnemonic is S + Regular mnemonic. Refer to section 6.2.8 for further details. 
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|7 RHO 0;7 RLO o| 




{is RHt 1 RL1 o| 




1 RH2 ; RL2 ] 




1 RH3 ; RU3 | 




1 RHl ; RL4 | 




1 RH5 \ RLS 1 




1 RH6 RLG 1 




1 RH7 ; RL7 | 




|is o| 


























1 NORMAL STACK POINTER (SEO. NO.) (NSPSEGl | 




15 1 SYSTEM STACK POINTER (OFFSET) j 


1 NORMAL STACK POINTER (OFFSET) (NSPOFF) | 



\r RHO 17 RLO o| 




1 15 RH1 1 RL1 1 




1 RH2 1 RL2 1 




1 RH3 1 RL3 1 




1 RH4 [ RL4 1 




[ RH5 ; RL5 | 




{ RH6 1 1 




1 flH7 I RLO RL7 1 




|15 o| 



























SYSTEM STACK POINTER 



( POINTER (NSP) 



? 



Z8001 General Purpose Registers 



Z8002 General Purpose Registers 



Register 



Binary 



Hex 



RQO RRO 



RR2 



RQ4 RR4 



RR6 



RQ8 RR8 



RRIO 



RQ12 RR12 



RRl-^ 



RO 


RHO 


0000 





Rl 


RHl 


0001 


1 


R2 


RH2 


0010 


2 


R3 


RH3 


0011 


3 


R4 


RH4 


0100 


4 


R5 


RH5 


0101 


5 


R6 


RH6 


0110 


6 


R7 


RH7 


0111 


7 


R8 


RLO 


1000 


8 


R9 


RLl 


1001 


9 


RIO 


RL2 


1010 


A 


Rll 


RL3 


1011 


B 


R12 


RL4 


1100 


C 


R13 


RL5 


1101 


D 


R14 


RL6 


1110 


E 


R15 


RL7 


nil 


F 



Binary Encoding for Register Fields 



SYSTEM STACK 
POINTER AFTER 
TRAP OR 
INTERRUPT 



SYSTEM STACK 
POINTER BEFORE 
TRAP OR 
INTERRUPT 



SYSTEM SP 
AFTER TRAP 
OR INTERRUPT 



SYSTEM SP 
BEFORE TRAP 
OR INTERRUPT 



PC SEGMENT 



Format oi Saved Program Status in the System Stack 
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CONTROL BITS 



|seg|s/n|epa| VI |Nvi|;>,v:-g*j c 1 z 1 s 


|pw| D 


"[:: 






1 PROGRAM COUNTER 1 


NONSEGMENTEO 
15 









1 i 


CONTROL BITS 


FLAGS 






|sEGJsm]EPA| VI |nV||^^^|^ ^1^1® 


|pvi D 


"! 


1 




^H PC SEGMENT NUMBER ^ 






. 




1 PROGRAM COUNTER OFFSET | 



Program Status Blocks 



10 16 



18 24 



20 32 



28 40 



38 56 

3C 60 

40 64 

44 68 



23A 570 



j SEG. NO. 1 


1 UPPER 1 


~ 00...D J 


Z8001 


OFFSET 


IMPLIED 
Z8002 




RESERVED 

EXTENDED 

INSTRUCTION 

TRAP 

PRIVILEGED 

INSTRUCTION 

TRAP 

SYSTEM 
CALL 
TRAP 

SEGMENT 
TRAP 

NONMASKABLE 
INTERRUPT 

NON-VECTORED 
INTERRUPT 

VECTORED 
INTERRUPTS 




RESERVED 


FCW 


FCW 


ISEGl 


PC 


PC OFFSET 


RESERVED 


FCW 


FCW 


ISEQl 


PC 


PC OFFSET 


RESERVED 


FCW 


FCW 


|SEG| 


PC 


PC OFFSET 


RESERVED 


NOT USED 


FCW 


ISEGl 


PC OFFSET 


RESERVED 


FCW 


FCW 


ISEGl 


PC 


PC OFFSET 


RESERVED 


FCW 


FCW 


ISEGl 


PC 


PC OFFSET 


RESERVED 


FCW 


FCW 


|SEG| 


PCi 


PC OFFSET 


IsegI 


PC2 


PC2 OFFSET 


|SEG| 


PCs 


PCs OFFSET 


j 


i 


ISEGl 


PCn 


PC„ OFFSET 



540 21 C 



Program Status Area 
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Condition 
Codes 



Code 


Meaning 


Flag Setting 


Binary 


F 


Always false* 




0000 




Always true 




1000 


Z 


Zero 


Z = I 


Olio 


NZ 


Not zero 


Z = 


1110 


C 


Carry 


C = 1 


0111 


NC 


No carry 


C = 


nil 


PL 


Plus 


S = 


1101 


MI 


Minus 


S = 1 


0101 


NE 


Not equal 


Z = 


1110 


EQ 


Equal 


Z = 1 


Olio 


OV 


Overflow 


V = 1 


0100 


NOV 


No overflow 


V = 


1100 


PE 


Parity even 


p = 1 


0100 


PO 


Parity odd 


P = 


1100 


GE 


Greater than 
or equal 


(S XOR V) = 


1001 


LT 


Less than 


(S XOR V) = 1 


0001 


GT 


Greater than 


(Z OR (S XOR V)) = 


1010 


LE 


Less than or 
equal 


(Z OR (S XOR V)) = 1 


0010 


UGE 


Unsigned 
greater than 
or equal 


C = 


nil 


ULT 


Unsigned 
less than 


C = 1 


0111 


UGT 


Unsigned 
greater than 


((C =0) AND (Z = 0)) = 1 


1011 


ULE 


Unsigned less 
than or equal 


(C OR Z) = 1 


oon 



This table provides the condition codes and the flag settings they represent. 

Note that some of the condition codes correspond to identical flag settings: i.e., Z-EQ, NZ-NE, 
NC-UGE, PE-OV, PO-NOV. 

"Presently not implemented in PLZ/ASM Z8000 compiler. 



7 6 5 4 3 2 


1 










1 


1 




15 14 13 12 11 10 


9 


8 7 6 


5 4 3 2 1 


11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


Address n 












1 




Address n (even) 




Address n 


+ 1 


1 UPPER BYTE 




1 , , 


LOWER BYTE I 


Address n 




Address n 


+ 1 


1 UPPER WORD/UPPER BYTE 1 1 


Address n + 2 




Address n 


+ 3 


1 1 LOWER WORD/LOWER BYTE 1 



BITS IN A BYTE 



BITS IN A WORD 



LONG WORD 



Addressable Data Elements 
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Z8000 

Addressing 

Modes 



Addressing Mode 



Operand Addressing 



Operand Value 



In the Instruction In a Register 



In Memory 



Register 



REGISTER ADDRESS I — K-l OPERAND 



h: 



The content of the 
register 



IM 



Immediate I o""*^" I 



In the instruction 



IR 



Indirect 
Register 



REGISTER ADDRESS I H ADDRESS 



h: 



The content of the location 
whose address is in the 
register 



DA 



Direct 
Address 



The content oi the location 
whose address is in the 
instruction 



Index 



REGISTER ADDRESS 



M INDEX j- 



BASE ADDRESS 



-—^^ »-j OPERAND I 



The content of the loca- 
tion whose address is the 
address in the instruction 
plus the content oi the 
working register. 



RA 



Relotive 
Address 



I PC VALUE |- 



DISPLACEMENT 



-»-^ >-| OPERAND I 



The content oi the location 
whose address is the 
content of the program 
counter, offset by the 
displacement in the 
instruction 



BA 



Bose 
Address 



REGISTER ADDRESS 



— »-{ BASE ADDRESS [— 



DISPLACEMENT 



-»-{^ >-| OPERAND I 



The content of the location 
whose address is the 
address in the register, 
offset by the displacement 
in the instruction 



BX 



Base 
Index 



REGISTER ADDRESS 




BASE ADDRESS 








REGISTER ADDRESS 


INDEX 


-<. 



The content of the loca- 
tion whose address is 
the address in a register 
plus the index volue in 
another register. 



*Do not use RO or RRO as indirect, index, or base registers. 



Powers 
of 2 
and 16 



2" 


n 


256 


8 


512 


.9 


1 024 


10 


2 048 


11 


4 096 


12 


8 192 


13 


16 384 


14 


32 768 


15 


65 536 


16 


131 072 


17 


262 144 


18 


524 288 


19 


1 048 576 


20 


2 097 152 


21 


4 194 304 


22 


8 388 608 


23 


16 777 216 


24 


Powers of 2 



2° 


= 


16° 


2- 


= 


16' 


2» 


= 


16^ 


212 


= 


16^ 


2'^ 


= 


le" 


2» 


= 


16= 


22. 


= 


16« 


228 


= 


16' 


2^ 


= 


168 


2* 


= 


16" 


2" 


= 1 


gio 


2« 


= 1 


6" 


2« 


= 1 


6'2 


2=2 


= 1 


6 '3 


2^ 


= 1 


6'' 


260 


;= 1 


6'= 



16° 

1 

16 

256 

4 096 

65 536 

1 048 576 

16 777 216 

268 435 456 

4 294 967 296 

68 719 476 736 

1 099 511 627 776 

17 592 186 044 416 

281 474 976 710 656 

4 503 599 627 370 496 

72 057 594 037 927 936 

1 152 921 504 606 846 976 

Powers oi 16 
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8 




7 




6 




5 




4 




3 




2 




1 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


















































1 


268,435,456 


1 


16,777,216 


1 


1 ,048,576 


1 


65,536 


1 


4,096 


1 


256 


1 


16 


1 


1 


2 


536,870,912 


2 


33,554,432 


2 


2,097,152 


2 


131,072 


2 


8,192 


2 


512 


2 


32 


2 


2 


3 


805,306,368 


3 


50,331,648 


3 


3,145,728 


3 


196,608 


3 


12,288 


3 


768 


3 


48 


3 


3 


4 


1,073,741,824 


4 


67,108,864 


4 


4,194,304 


4 


262,144 


4 


16,384 


4 


1,024 


4 


64 


4 


4 


5 


1,342,177,280 


5 


83,886,080 


5 


5,242,880 


5 


327,680 


5 


20,480 


5 


1,280 


5 


80 


5 


5 


6 


1,610,612,736 


6 


100,663,296 


6 


6,291,456 


6 


393,216 


6 


24,576 


6 


1,536 


6 


96 


6 


6 


7 


1,879,048,192 


7 


117,440,512 


7 


7,340,032 


7 


458,752 


7 


28,672 


7 


1,792 


7 


112 


7 


7 


8 


2,147,483,648 


8 


134,217,728 


8 


8,388,608 


8 


524,288 


8 


32,768 


8 


2,048 


8 


128 


8 


8 


9 


2,415,919,104 


9 


150,994,944 


9 


9,437,184 


9 


589,824 


9 


36,864 


9 


2,304 


9 


144 


9 


9 


A 


2,684,354,560 


A 


167,772,160 


A 


10,485,760 


A 


655,360 


A 


40,960 


A 


2,560 


A 


160 


A 


10 


B 


2,952,790,016 


B 


184,549,376 


B 


11,534,336 


B 


720,896 


B 


45,056 


B 


2,816 


B 


176 


B 


11 


C 


3,221,225,472 


C 


201,326,592 


C 


12,582,912 


C 


786,432 


C 


49,152 


C 


3,072 


C 


192 


C 


12 


D 


3,489,660,928 


D 


218,103,808 


D 


13,631,488 


D 


851,968 


D 


53,248 


D 


3,328 


D 


208 


D 


13 


E 


3,758,096,384 


E 


234,881,024 


E 


14,680,064 


E 


917,504 , 


E 


57,344 


E 


3,584 


E 


224 


E 


14 


F 


4,026,531,840 


F 


251,658,240 


F 


15,728,640 


F 


983,040 


F 


61,440 


F 


3,840 


F 


240 


F 


15 



6 5 4 3 

Hexadecimal and Decimal Interger Conversion Table 



To Convert Hexadecimal to Decimal 

1 . Locate the column of decimal numbers corresponding to 
the left-most digit or letter of the hexadecimal: select 
from this column and record the number that cor- 
responds to the position of the hexadecimal digit or 
letter. 

2. Repeat step 1 for the units (second from the left) 
position. 

3. Repeat step 1 for the units (third from the left) position. 

4. Add the numbers selected from the table to form the 
decimal number. 

To convert integer numbers greater than the capacity of 
the table, use the techniques below: 



Hexadecimal to Decimal 

Succesive cumulative mulitplication from left to right 
adding units position. 

Example: D34i6 = 3380io 
D = 13 

xl6 

208 

3 = +_13 

211 
xl6 
3376 

4 = _+4 

3380 



Example: 



Conversion of 
Hexadecimal Value 
D34 

3328 



1. D 

2. 3 48 

3. 4 6 

4. Decimal 3380 



To Convert Decimal to Hexadecimal 

1 . (a) Select from the tabel the highest decimal number 

that is equal to or less than the number to be 
converted. 

(b) Record the hexadecimal of the column containing 
the selected number. 

(c) Subtract the selected decimal from the number to be 
converted. 

2. Using the remainder from step 1(c) repeat all of step 1 
to develop the second position of the hexadecimal (and 
a remainder). 

3. Using the remainder from step 2 repeat all of step 1 to 
develop the units position of the hexadecimal. 

4. Combine terms to form the hexadecimal number. 

Decimal to Hexadecimal 

Divide and collect the remainder in reverse order. 
Example: 3380io = D34i6 Example: 

1613380 remainder 



Ljii^. 



16 
161 13 



1. D 



Conversion of 
Decimal Value 

3380 

- 3328 
52 



2. 3 



3. 4 



-4 



4. Hexadecimal D34 
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ASCII 
Characters 



Hexadecimal 



Character 



Meaning 



Hexadecimal 



Character 



00 

01 

02 

03 

04 

05 

06 

07 
-08 

09 

OA 

OB 

OC 

OD 

OE 

OF 
■ lo- 
ll 

12 

13 

14 

15 

16 

17 

18 

19 

lA 

IB 
-IC 

ID 

IE 

IF 
■20 - 

21 

22 

23 
■24 ■ 

25 

26 

27 
■28 

29 

2A 

2B 

2C 

2D 

2E 

2F 

30 

31 

32 

33 
-34 

35 

36 

37 
■38 

39 

3A 

3B 

3C 

3D 

3E 

3F 



NUL 
SOH 
STX 
ETX 
EOT 
ENQ 
ACK 
BEL 

■ BS - 
HT 
LF 
VT 
FF 
CR 
SO 
SI 

■ DLE- 
DCl 
DC2 
DC3 
DC4 ■ 
NAK 
SYN 
ETB 
CAN- 

EM 
SUB 
ESC 
FS - 
GS 
RS 
US 
SP- 



NULL Character 

Start of Heading 

Start of Text 

End of Text 
■ End of Transmission - 

Enquir-y 

Acknowledge 

Bell 
-Backspace 

Horizontal Tabulation 

Line Feed 

Vertical Tabulation 

Form Feed 



Carriage Return 
Shift Out 
Shift In 

Data Link Escape 

Device Control 1 
Device Control 2 
Device Control 3 

Device Control 4 

Negative Acknowledge 
Synchronous Idle 
End of Transmission Block 
- Cancel 



End of Medium 
Substitute 
Escape 
• File Separator — 
Group Separator 
Record Separator 
Unit Separator 
Space 



40 
41 
42 
43 
44 
45 
46 
47 
-48 ■ 
49 
4A 



69 

6A 

6B 

6C 

6D 

6E 

6F 

70 • 

71 

72 

73 

74 

75 

76 

77 

78 

79 

7A 

7B 

7C 

7D 

7E 

7F 



4C 


L 


4D 


M 


4E 


N 


4F 


O 


50 


p 


51 


Q 


52 


R 


53 


S 


54 


T 


55 


U 


56 


V 


57 


w 


58 


X 


59 


Y 


5A 


Z 


5B 


[ 


5C 






5D 


] 


5E 


'^ 


5F 


_ 


60- 






61 


a 


62 


b 


63 


c 


64 


d 


65 


e 


66 


f 


67 


g 


68 


h 



DEL 



Delete 
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B _ 



Til 



■7-;i 



Zilog 



Appendix D 



Glossary of address: A number that specifies one par- 
Terms ticular element in a set of similar elements. 
May be either a memory address or an I/O 
address (q.q.v). (See also segmented address, 
logical address, physical address.) 

address space: A set of addresses. The Z8000 
can access eight separate address spaces: 
normal-mode program memory space, system- 
mode program memory space, normal-mode 
data memory space, system- mode data memory 
space, normal-mode stack memory space, 
system-mode stack memory space, standard 
I/O space, and special I/O space. (See normal 
mode, system mode, program memory address 
space, data memory address space, stack 
memory address space, standard I/O address 
space, and special I/O address space.) 

addressing mode: The way in which the 
address of an operand (q.v.) is specified. 
There are eight addressing modes: Register, 
Immediate, Indirect Register, Direct Address, 
Index, Base Address, Relative Address, Base 
Index (q.q.v). 

autodecrement: The contents of a register are 
decremented and then used as specified by the 
instruction. 

autoincrement: The contents of a register are 
used as specified by the instruction and then 
incremented. 

Base address (BA) addressing mode: A 

based address consists of a register that con- 
tains the base and a 16-bit displacement (q.v.). 
The displacement is added to the base and the 
resulting address indicates the effective 
address (q.v.). In nonsegmented mode, the 
base address is held in a word register (q.v.) 
and the displacement is in the instruction. In 
segmented mode, the segmented base address 
is held in a register pair and the displacement 
is in the instruction. 

Base Index (BX) addressing mode: Based 
Indexed addressing is similar to Based 
addressing except that the displacement 
("index"), as well as the base, is held in a 
register. In nonsegmented mode, the base 
address is held in a word register and the 
index is held in a word register. In segmented 
mode, the segmented base address is held in a 
register pair (q.v.) and the index is held in a 
word register. 



BCD digit: A Binary Coded Decimal digit is 
an encoding of the ten decimal digits into a 
4-bit code that is simply the first ten binary 
numbers in the binary number system (starting 
with 0). This code is used to represent and 
process numbers in the base- 10 (decimal) 
format. 

bus: A group of signal lines, which connects 
the devices in a system. 

Bus-Disconnect state: The CPU state during 
which the CPU is not the bus master and may 
not initiate transactions (q.v.) on the bus. 

bus master: The device in control of the bus. 
Must be a device that is able to initiate 
transactions. 

bus request: A request for control of the bus. 

byte: A byte is eight contiguous bits; a byte in 
memory starts on an addressable byte 
boundary. 

byte register: An 8- bit register. The Z8000 
CPU contains 16 general-purpose byte 
registers, designated RLn and RHn (n - 0-7). 

clock cycle: One cycle of the CPU clock, 
beginning with a rising edge. 

condition: An event detected by the hardware 
and indicated by setting the appropriate flag. 
A condition is caused by the execution of an 
instruction and is always reproducible. The 
Z8000 has six flags to record these events, 
called status Hags (q.v.). 

context switching: Interrupting the activity in 
progress and switching to another activity. A 
context switch involves saving for later restora- 
tion the contents of the general- purpose 
registers, the Program Counter and the Flag 
and Status Word (q.v.). 

CPU state: Either Running state, Stop/Relresh 
state, or Bus-Disconnect state (q.q.v.). 

data memory address space: A memory 
address space (q.v.) that is identified by the 
status codes 1000 or 1010. 

data structure: A logical organization of 
primitive elements (e.g. byte or word) whose 
format and access conventions are well- 
defined. Examples of data structures are 
tables, lists and arrays. 
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Glossary of data type: The way in which bits are grouped 
Terms and interpreted. For an instruction, the data 

type of an operand determines its size and the 
significance of its bits. Operand data types 
include byte, word, long word, byte string, 
word string, and BCD digit. 

Direct Address (DA) addressing mode: In this 
mode, the operand address is contained within 
the instruction. 

displacement: A number contained in the 
instruction for use in calculating the effective 
address (q.v.) of an operand. The displace- 
ment is added to the contents of a register dur- 
ing the calculation. 

DMA: Direct Memory Access is a method for 
transferring data to or from main memory at 
high speed by avoiding the CPU registers. 

effective address: The address obtained after 
indirect or indexing modification. In non- 
segmented mode, the effective address is a 
16-bit number. In segmented mode, the effec- 
tive address consists of a 7-bit segment number 
and 16-bit offset. In systems with memory 
management, the effective address is the 
logical address which must be translated to 
obtain the physical memory address. 

flags: Bits in the Flag and Control Word 
(q.v.) that indicate conditions (q.v.). 

Flag and Control Word: One of the two Pro- 
gram Status registers; it contains flags (q.v.) 
and bits that control the operation of the CPU. 

Immediate (I) addressing mode: In this 
mode, the operand is contained within the 
instuction. 

Index (X) addressing mode: In this mode, the 
operand address is obtained by adding the 
contents of an index register (q.v.) to a base 
address contained in the instruction. 

index register: A word register used to con- 
tain a displacement for use in effective address 
calculation. 

Indirect Register (IR) addressing mode: In 

this mode, the operand address is contained 
within a register. 

instruction fetch: An access to program 
memory address space (q.v.). 

interrupt request: An event other than a trap 
or jump or call instruction that changes the 
normal flow of instruction execution. (See non- 
maskable, non-vectored, and vectored 
interrupts.) 

interrupt service routine: The routine exe- 
cuted in response to an interrupt. 

interrupt/trap acknowledge transaction: The 

transaction initiated by the CPU in response to 
an interrupt or trap. Obtains an identifier word 
from the interrupting device or memory man- 
agement hardware. 



I/O address: The address of an I/O port, 
always 16 bits long. Word ports may have even 
or odd addresses. Special I/O byte ports are 
even. Standard I/O byte ports are odd. 

I/O transaction: A transaction that transfers 
data to or from a peripheral device or memory 
management hardware. 

logical address: The address manipulated by 
the programmer, used by instructions and out- 
put by theZSOOl. 

long word: A long word is 32 contiguous bits; 
a long word in memory starts on an even 
addressable byte boundary. 

machine cycle: One basic CPU operation, 
starting with a bus transaction (q.v.). 

memory address: An address specifying a 
location in memory. Word and long-word 
addresses must be even, byte addresses may 
be even or odd. 

memory management: The process of trans- 
lating logical addresses into physical 
addresses (q.q.v.), plus certain protection 
functions. 

memory transactions: A transaction that 
transfers data to or from main memory. 

normal mode: A Running-state (q.v.) mode in 
wh_ich the S/N flag in the FCW is and the 
N/S line is High. In this mode, the CPU may 
not eyiecxxie privileged instructions (q.v.). 

non-maskable interrupts: Interrupts (q.v.) 
which cannot be disabled. 

nonsegmented mode: A Running- state mode 
of the Z8001 CPU. In this mode, all addresses 
are generated with the same segment 
number (q.v.). 

non- vectored interrupts: Interrupts (q.v.) 
which do not use the identifier word as a vec- 
tor to an interrupt service routine (q.v.). 

offset: In a Z8001 CPU, the 16-bit value that 
appears on the AD lines when an address is 
generated. 

operand: An item of data operated on by an 
instruction. 

physical address: The address required for 
accessing the memory, obtained from the 
logical address generated by the Z8001 by 
memory management hardware, for example, 
the Z8010 Memory Management Unit. 

privileged instruction: An instruction intend- 
ed for use primarily by an operating system, 
which can be executed only in system mode. 
In general, instructions that change the pro- 
cessor state or perform I/O are privileged. 

Program Counter (PC): One of the two Pro- 
gram Status registers (q.v.). Contains the 
address of the current instruction word. 
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Glossary of program memory address space: The 
Terms memory address space (q.v.) indicated by the 

status codes (1100 or 1101). 

Program Status Area: The area in memory- 
reserved for the starting program status of the 
interrupt and trap service routines. 

Program Status Area Pointer: The register 
that contains the starting address of the Pro- 
gram Status Area. 

Program Status registers: The two registers 
(PC and FCW) that contain the program 
status. 

refresh counter: A register that controls the 
Z8000 dynamic memory, periodic-refresh 
mechanism. Used to set the refresh rate and to 
enable the mechanism. 

refresh cycle: A type of transaction used to 
refresh dynamic memory. It is three clock 
cycles long. 

Refresh/Stop state: A CPU state entered 
whenever the STOP line is asserted. A con- 
tinuous stream of refresh cycles (q.v.) is 
generated. 

register: A storage location in hardware logic 
other than the memory. Bits within a register 
are numbered from 0, with the least significant 
being the rightmost. See also byte register, 
word register, register pair, and register quad. 

Register (R) addressing mode: In this mode, 
the operand is in a general-purpose register. 

register pair: One of eight pairs of general- 
purpose word registers, designated RRn 
(n = 0, 2, 4, ..., 12, 14). 

register quad: One of four groups of four 
word registers, designated RQn (n = 0, 4, 
8, 12). 

Relative Address (RA) addressing mode: In 

this mode, the operand address is calculated 
by adding a displacement found in the instruc- 
tion to the current PC value. 

request: Either an interrupt r equest , bus 
request, resource request, or STOP request 
(qq.v.). An external device requests that the 
CPU perform some action. 

reset: An internal CPU operation that initial- 
izes the Prog ram Sta tus registers. It is acti- 
vated by the RESET line. 

Running state: One of the three CPU states. 
In this state, the CPU is fetching and exe- 
cuting instructions or handling interrupts. 

segment: In a Z8001, a set of adjacent 
memory addresses (up to 64K) with the same 
segment number (q.v.) on lines SN0-SN5. 

segment number: A number specifying a 
memory segment (q.v.). Placed on the 
SNo-SNg lines during memory transactions in 
Z8001 system. Part of a segmented 
address (q.v.). 



segmented address: In Z8001 CPU's, a 23-bit 
value consisting of a 7-bit segment number 
(q.v.) and a 16-bit offset (q.v.). 

segmented mode: One of the Running- state 
modes of the Z8001 CPU. In this mode, CPU 
generates addresses that can have different 
segment numbers. 

special I/O address space: An I/O address 
space (q.v.) that is identified by the status 
code 1011. Used to access memory manage- 
ment hardware. 

stack: A data structure used for temporary 
storage or for procedure and interrupt service 
routine linkages. A stack uses the last-in, first- 
out concept. As items are added to, or pushed 
onto, the stack, the stack pointer decrements; 
as items are removed from, or popped off, the 
stack, the stack pointer increments. 
stack memory address space: A memory 
address space (q.v.) that is identified by the 
status codes 1001 and 1011. 

stack pointer: A general- purpose register 
indicating the top (lowest address) of a stack. 

standard I/O address space: An I/O address 
space (q.v.) that is identified by the status 
code 0010. Used for accessing peripherals. 

status code: A 4-bit encoding of the CPU's 
current transaction, for example, internal 
operation, segment trap acknowledge, or stack 
memory request. 

status flags: Status flags are set according to 
the outcome of certain instructions to direct 
the subsequent flow of the program as neces- 
sary. There are six status flags: Carry, Zero, 
Sign, Parity/Overflow, Decimal Adjust and 
Half Carry. The first four are grouped together 
to determine the condition code, the last two 
are used in programs manipulating BCD 
digits. 

status lines: The lines ST0-ST3, which contain 
the status code during transactions. 

stop request: A request that is made by acti- 
vating the STOP line. 

Stop/Refresh state: See Refresh/Stop state. 

system mode: A Running-state mode (q.v.) in 
wh^ch the S/N flag in the FCW is 1 and the 
N/S line is Low. In this mode, the CPU may 
exercise privileged instructions (q.v.). 

transaction: One of the basic bus operations. 
A transaction lasts three or more clock cycles 
and covers a single data movement on the bus. 
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Glossary of trap: A condition that occurs at the end of an 

Terms instruction that caused an illegal operation. 

The Z8000 traps are internal traps arising from 
system call, unimplemented instruction and 
privileged instructions executed in normal 
mode, and an external trap, the segmentation 
trap, arising from memory access violations in 
systems with memory management. A trap is 
similar to an interrupt in that it causes the exe- 
cuting program to be interrupted and the Pro- 
gram Status registers to be saved on the system 
stack. Traps cannot be disabled. 

vectored interrupts: Interrupts (q.v.) which 
use the identifier word as a vector to the inter- 
rupt service routine (q.v.). May be 
disabled. 



WAIT cycle; A clock cycle during which the 
WAIT line is active. Used to prolong trans- 
actions, since no signal line is sampled while 
WAIT is active. 

word: Two contiguous bytes (16 bits) starting 
on an even addressable byte boundary. Bits 
are numbered from the right, through 15. A 
word is identified by the address of the byte 
containing the most significant bit, bit 15. 

word register: A 16-bit register. 
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